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К огда простой и бесхитростный 
отечественный пользователь слышит 
где-либо слова “ резидентная 
программа ", он мгновенно проникается 
благоговейным уважением к говорящему. 
Ведь ЭТО — что-то совершенно 
невообразимое, почти 
сверхъестественное и, уж во всяком 
случае, недоступное пониманию 
простого смертного. Фантастические 
смены декораций, головокружительные 
трюки, потрясающие эффекты, словно 
по мановению волшебной палочки 
невесть откуда появляющиеся 
могущественные, блистательные 
возможности... 

И оказывается, во всей этой 
чертовщине тоже можно разобраться. 
Говорят даже, что ЭТО доступно 
пониманию каждого! 

Бррррр... Аж мороз по коже!.. 

А может, стоит и самому 
попробовать? Зажмурить глаза и... 


Этот безумный, 
безумный, безумный мир 
резидентных программ 


Знание некоторых принципов легко 
возмещает незнание некоторых фактов. 

Гельвеций 

Резидентной (или Т8К, от английского Тегшіпаіе & 
8іау КезісіепО программой называется программа, по- 
стоянно находящаяся в оперативной памяти и активи- 
зируемая по прерыванию. 

Область применения резидентных программ необы- 
чайно широка. Это и “хелперы**, позволяющие полу- 
чать информацию, что называется, “на кончике паль- 
цев“, и сервисные программы, такие как “калькуля- 
тор“ или “записная книжка**, которыми вы можете 
воспользоваться в любое время, работая с любой дру- 
гой программой, и программные русификаторы, и 
многое, многое другое. 


В последние годы часто появляются резидентные 
программы, во многом похожие на загружаемые драй- 
веры М8-И08 (с расширением .8Ѵ8). Связано это с 
тем, что классический драйвер сложно писать и еще 
сложнее отлаживать. Кроме того, для установки или 
снятия загружаемого драйвера необходимо изменить 
файл СОЫРІС.8Ѵ8 и перезагрузить операционную 
систему, а для резидентных программ этого не требу- 
ется. Примерами таких “псевдодрайверов** могут слу- 
жить широко известный драйвер НГМД 800. СОМ и 
большинство драйверов мыши. 

Разработка резидентных программ требует учета 
многих особенностей операционной системы, а зачас- 
тую и аппаратной части и по праву считается одной 
из наиболее трудных задач программирования для 
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ЭТОТ БЕЗУМНЫЙ, БЕЗУМНЫЙ, БЕЗУМНЫЙ МИР РЕЗИДЕНТНЫХ ПРОГРАММ 


Таблица 1 


ІВО 

Номер 

преры- 

вания 

Адрес 

порта 

регистра 

маски 

Номер 

бита 

Устройство 

0 

08Н 

21Н 

0 

системный таймер 

1 

09Н 

21Н 

1 

клавиатура 

2 

ОАН 

21Н 

2 

канал ввода-вывода 

8 

70Н 

А1Н 

0 

часы реального 
времени (только АТ) 

9 

71Н 

А1Н 

1 

программно переводятся 
в ІР02 (только АТ) 

10 

72Н 

А1Н 

2 

резерв 

11 

73Н 

А1Н 

3 

резерв 

12 

74Н 

А1Н 

4 

резерв 

13 

75Н 

А1Н 

5 

математический 
сопроцессор (только АТ) 

14 

76Н 

А 1 Н 

6 

жесткий диск (только АТ) 

15 

3 

77Н 

ОВН 

А1Н 

21Н 

7 

3 

резерв 

С0М1 (С0М2 на АТ) 

4 

ОСН 

21Н 

4 

С0М2 (С0М1 на АТ) 

5 

ООН 

21Н 

5 

жесткий диск на ХТ 
(1.РТ2 на АТ, на ІВМ РС 
не используется) 

6 

ОЕН 

21Н 

6 

контроллер НГМД 

7 

ОРН 

21Н 

7 

1.РТ1 


ПЭВМ. Тем не менее, вы увидите, что эта 
задача вполне разрешима. 

Предполагается, что читатель имеет пред- 
ставление о ООЗ и принципах работы компью- 
тера. В то же время изложение ведется на са- 
мом элементарном уровне, а все нетривиальные 
идеи подробно объясняются. Поэтому автор на- 
деется, что статья будет понятна и полезна 
даже тем, кто только начинает осваивать про- 
граммирование на ассемблере. 

Разумеется, в небольшой журнальной статье 
невозможно рассказать обо всем. При отборе 
материала автор старался руководствоваться 
известным изречением французского философа. 

Более подробную информацию по затронутым 
вопросам можно найти в технической докумен- 
тации по 003 и ВІ05. 

Введение в прерывания ІВМ РС 

Прерывание (іпіеггирі) — это аппаратная 
функция, вызывающая приостановку операций 
центрального процессора, запоминание его со- 
стояния и выполнение специальной программы, кото- 
рая называется программой обработки прерывания 
(іпіеггирі зегѵісе гоиііпе — І5К) или обработчиком 
прерывания (іпіеггирі Ьапсііег). 

Существует три класса прерываний: внутренние, 
внешние (аппаратные) и программные. Внутренние 
прерывания инициируются состоянием самого процес- 
сора, внешние — сигналом, подаваемым в процессор 
другими компонентами системы, а программные пре- 
рывания — специальной командой выполняющейся 
программы. Так, в ІВМ РС при попытке деления на 
ноль происходит внутреннее прерывание, при выпол- 
нении команды іпі — программное, а при любом на- 
жатии на клавишу или ее отпускании — аппаратное. 
В литературе внутренние и программные прерывания 
часто объединяются в один класс и рассматриваются 
совместно. 

Идея прерывания не нова. Механизм аппаратных 
прерываний как средства реакции на внешние события 
впервые возник в 1954 году на ІЖІѴАС 1103, а уже в 
1958 году он использовался для организации асин- 
хронного ввода-вывода в ІВМ 709. 

Внутренние прерывания, появившиеся не позднее 
1964 года и предусмотренные уже в ЭВМ серии 
ІВМ 360, позволяют процессору контролировать ход 
вычислений и принимать необходимые меры при воз- 
никновении ошибок, таких как деление на ноль или 
исчезновение порядка в операциях с действительными 
числами. 

Программные прерывания служат удобным интер- 
фейсом между прикладными программами и операци- 
онной системой. На самом деле они ничего не преры- 
вают, а являются формой обращения к процедуре. 
Когда программе пользователя требуется выполнение 
какой-либо функции операционной системы, она вы- 
зывает ее, вырабатывая соответствующее прерывание. 


При этом можно не знать, в каком месте оперативной 
памяти находится подпрограмма, реализующая фун- 
кцию, тем более что физические адреса компонентов 
операционной системы могут меняться. 

Микропроцессоры семейства 8086 способны обраба- 
тывать 256 типов прерываний. Каждое прерывание 
имеет номер от 0 до 255. Часть прерываний зарезер- 
вирована в качестве внутренних или используется 
внешними устройствами. 

Для управления аппаратными прерываниями в 
ІВМ РС и ХТ используется один, а в АТ два 
однокристальных контроллера прерываний ІМ- 
ТЕЬ 8259, которые формируют номер прерывания и 
сигнал запроса ПЧТ, поступающий на одноименный 
вход микропроцессора. Каждый микроконтроллер 
имеет 8 уровней приоритета (ІК(2). При одновремен- 
ном поступлении нескольких запросов на прерывание 
в первую очередь обслуживается устройство с более 
высоким приоритетом. Наивысший приоритет соответ- 
ствует уровню 0. Восемь дополнительных уровней АТ 
имеют приоритет между ІК()2 и ІК(}3 (см. таблицу 1). 

Прерывания, поступающие на вход ШТ, обрабаты- 
ваются микропроцессором только в том случае, если 
флаг ІР установлен в 1 . Можно запретить эти преры- 
вания (сбросить флаг ІР) командой сП и разрешить 
командой 5Іі. Если запрос на прерывание приходит в 
момент, когда аппаратные прерывания запрещены, то 
он запоминается и начнет обслуживаться, как только 
будут разрешены прерывания. Все последующие за- 
просы будут игнорироваться контроллером прерываний 
до тех пор, пока не будет “отработано 1 * задержанное 
прерывание. По этой причине прерывания допускается 
запрещать лишь на очень короткие промежутки вре- 
мени, необходимые для выполнения критических уча- 
стков программы. Команды сіі и $1і обычно использу- 
ются парами: каждой команде сіі соответствует отме- 
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няющая ее команда 5ІІ. Несоблюдение этого правила 
может привести к тому, что прерывания так и оста- 
нутся запрещенными. При этом остановится си- 
стемный таймер, заблокируется клавиатура, станут 
невозможными операции с дисками. Вы не сможете 
ввести ни одной команды и, вообще, каким-либо обра- 
зом “достучаться 1 * до операционной системы. Един- 
ственный выход в такой ситуации — нажать кнопку 
сброса (КезеО. Повторное выполнение команд сіі, 
если флаг ІР сброшен, и хіі, если он установлен, не 
оказывает влияния на микропроцессор. 

Существует возможность запретить не все, а лишь 
избранные аппаратные прерывания записью единицы 
в соответствующий разряд регистра маски прерываний 
(ІМК) микроконтроллера ШТЕЬ 8259. Адреса связан- 
ных с этим регистром портов ввода-вывода и номера 
битов маски приведены в таблице 1 . Для разрешения 
прерывания нужно записать ноль в тот же разряд. 
Следующий пример демонстрирует работу с ІМК. 


іп 

а1,21Н 

; Читаем ІМН (не документировано). 

ог 

аі, 00000010В 

; Маскируем первыя бит (запрещаем 

оиі 

21Н,а1 

; прерывание от клавиатуры). 

іп 

а1,21Н 

; Разрешаем прерывание. 

апсі 

аі, 11111101В 


оиі 

21В, аі 



Есть одно внешнее прерывание, которое не может 
быть маскировано. Это так называемое немаскируемое 
прерывание (NN11). Оно имеет номер 02Н, обладает 
более высоким приоритетом, чем остальные аппарат- 
ные прерывания, и вызывается только в самых эк- 
стренных случаях: при обнаружении сбоев микросхем 
памяти, отключении питания, а также при некоторых 
ошибках сопроцессора. 

Работу с программными прерываниями обеспечива- 
ет команда іпі, имеющая синтаксис 

іпі номер_прерывания 

В принципе, с помощью этой команды можно вы- 
звать любое из 256 прерываний, на практике же ею 
следует пользоваться только для обращения к сервис- 
ным процедурам Д08 и ВІ08 или к собственным ре- 
зидентным процессам. 



Большая часть системного сервиса Д08 — так на- 
зываемые функции Б08 — используют для своего вы- 
зова прерывание 21 Н. Ниже будет более подробно 
рассказано о применении некоторых программных 
прерываний и функций 005. 

При возникновении прерывания, независимо от 
того, происходит оно в самом микропроцессоре, выра- 
батывается контроллером прерываний или командой 
іпі, выполняются одни и те же действия, называемые 
последовательностью прерывания. Если данное пре- 
рывание разрешено, то процессор завершает текущую 
команду, помещает в стек содержимое регистров фла- 
гов, С5 и ІР, после чего сбрасывает флаги ІР и ТР 
(запрещает аппаратные прерывания и режим трасси- 
ровки) и вычисляет адрес соответствующего вектора 
прерывания. Векторы прерываний образуют таблицу 
размером 1К, расположенную в начале ОЗУ. Каждый 
вектор представляет собой два 16-разрядных слова, 
размещенных в соседних ячейках памяти, причем в 
ячейке с меньшим адресом (четным) содержится сме- 
щение, а в следующей ячейке — сегментный адрес 
обработчика прерывания. Таким образом, вектор пре- 
рывания с номером N находится по адресу 0000:4*К’ . 
Первое слово вектора прерывания помещается в ІР, 
второе — в С8, при этом управление передается про- 
грамме, адрес которой содержится в векторе прерыва- 
ния. По завершении обработки прерывания из стека в 
обратном порядке извлекается содержимое регистров 
ІР, С8 и флагов, и управление возвращается прерван- 
ной программе. 

Использование прерываний 

в резидентных программах 

Любая резидентная программа содержит один или 
несколько взаимодействующих друг с другом обработ- 
чиков прерываний, которые обеспечивают запуск про- 
граммы и выполняют некоторые служебные функции. 

Обработчик прерывания похож на обычную про- 
граммную процедуру с учетом следующих особенно- 
стей: 

1) обработчик всегда имеет атрибут Гаг; 

2) при вызове обработчика сохраняется не только ад- 
рес возврата, но и регистр флагов; 

3) возврат в прерванную программу осуществляется 
инструкцией ігеі, а не геі, как в случае обычных 
процедур. Впрочем, если не нужно восстанавливать 
регистр флагов (например, при возврате значений в 
этом регистре), то возможно использование команды 
геі 2; 

4) вызов обработчика прерывания происходит не по 
адресу, а по номеру вектора прерывания, т.е. всегда 
используется косвенная адресация в памяти. 

При создании обработчиков прерываний следует 
помнить, что сегментные регистры 05, Е5 и 58 после 
прерывания сохраняют прежние значения, поэтому 
внутри обработчика нужно либо использовать адреса- 
цию только относительно регистра С5, применяя, где 
требуется, префикс переназначения сегмента, либо 
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должным образом установить сег- 
ментные регистры, разумеется, 
предварительно сохранив их старые 
значения. 

Псевдодрайверы, обрабатыва- 
ющие поступающие от прикладных 
программ запросы на обслужива- 
ние, могут запускаться с помощью 
программного прерывания, тогда 
как “выпрыгивающие" (рорир) ре- 
зидентные программы вынуждены 
использовать аппаратные пре- 
рывания, чаще всего — от клави- 
атуры (активизация по “горячей" 
клавише). 

Работа с аппаратными прерыва- 
ниями имеет некоторые особенно- 
сти. Поскольку эти прерывания мо- 
гут возникнуть в любое время, 
обработка их должна быть абсо- 
лютно незаметной для прерванной 
программы. Это значит, что обра- 
ботчики аппаратных прерываний (в 
отличие от обработчиков програм- 
мных прерываний) должны сохра- 
нять все регистры, включая флаги. 

Аппаратные прерывания нельзя 


Таблица 2 


Скан-код 

Клавиша 

Скан-код 

Клавиша 

Скан-код 

Клавиша 

01Н 

1 

Езс 

ЮН 

29 

І_еРР СРгІ 

[1] 

39Н 

57 

Зрасе 

02Н 

2 

1 

| 

1ЕН 

30 

а 

А 


ЗАН 

58 

Сарз 1_оск 

ОЗН 

3 

2 

@ 

1РН 

31 

3 

3 


ЗВН 

59 

Р1 

04Н 

4 

3 

и 

20Н 

32 

б 

0 


ЗСН 

60 

Р2 

05Н 

5 

4 

$ 

21Н 

33 

г 

р 


ЗОН 

61 

РЗ 

06Н 

6 

5 

% 

22Н 

34 

я 

с 


ЗЕН 

62 

Р4 

07Н 

7 

6 


23Н 

35 

ь 

н 


ЗРН 

63 

Р5 

08Н 

8 

7 

& 

24Н 

36 

5 

ц 


40Н 

64 

Р6 

09Н 

9 

3 

А 

25Н 

37 

к 

К 


41Н 

65 

Р7 

ОАН 

10 

9 

( 

26Н 

38 

1 

і_ 


42Н 

66 

Р8 

ОВН 

11 

0 

) 

27Н 

39 




43Н 

67 

Р9 

ООН 

12 



28Н 

40 

1 

" 


44Н 

68 

РІО 

ООН 

13 

= 

+ 

29Н 

41 

* 

~ 


45Н 

69 

Цит 1_оск 

ОЕН 

14 

ВаскЗрасе 

2АН 

42 

1_еРР 

зи 

ІРР 

46Н 

70 

ЗРгоІ 1 1_оск 

ОРН 

15 

Тар 

2ВН 

43 

\ 

1 


47Н 

71 

Ноте 7 [3] 

ЮН 

16 

а 

0 

2СН 

44 

2 

г 


48Н 

72 

Аггом/Чр 8 [3] 

11Н 

17 

V* 

М 

2ЭН 

45 

X 

X 


49Н 

73 

РдОр 9 [3] 

12Н 

18 

е 

Е 

2ЕН 

46 

С 

с 


4АН 

74 

Сгеу Міпиз. 

13Н 

19 

г 

В 

2РН 

47 

V 

V 


4ВН 

75 

АггомАР 4 [3] 

14Н 

20 

1: 

Т 

ЗОН 

48 

ь 

в 


4СН 

76 

5 [3] 

15Н 

21 

У 

У 

31Н 

49 

П 

N 


40Н 

77 

АггоѵѵВН 6 [3] 

16Н 

22 

и 

11 

32Н 

50 

т 

м 


4ЕН 

78 

Сгеу Ріиз 

17Н 

23 

і 

I 

ЗЗН 

51 


< 


4РН 

79 

Епб 1 [36 

18Н 

24 

о 

0 

34Н 

52 


> 


50Н 

80 

АггоѵѵОп 2 [3] 

19Н 

25 

р 

р 

35Н 

53 

/ 

? 


51Н 

81 

Рдйп 3 [3] 

1АН 

26 

і 

< 

36Н 

54 

НідІіГ 

знірр 

52Н 

82 

Іпз 0 [3,] 

1ВН 

27 

) 

> 

37Н 

55 

РгРЗс 

А 

Г 2 1 

53Н 

83 

Оеі . [3] 

1СН 

28 

ЕпРег 

38Н 

56 

І_еРР АІР 

И] 





Примечания: 

[1] Прилагательное 1_еРР относится к 101-клавишной клавиатуре. 

[2] Отсутствует на 101-клавишной клавиатуре. 

[3] Малая цифровая клавиатура. 


игнорировать. Установленный вами 
обработчик прерывания, помимо запуска резидентной 
программы, должен выполнить определенные дей- 
ствия, конкретное содержание которых зависит от 
типа обслуживаемого устройства. Самый простой спо- 
соб “отработать* 1 аппаратное прерывание — обра- 
титься по адресу исходного обработчика. Это можно 
сделать, использовав вместо команды ігеі команду 
,)тр йяогй РТН [01й_1пІ_ѵесІ] 

либо имитировав прерывание по старому вектору 
ризЫ 

саіі йѵогй РТН [Оіа_іпІ_ѵесІ) 

Здесь 0 1 <3 і п I ѵес I — двойное слово, в котором сохра- 

нен исходный вектор прерывания. 

Вообще, во избежание конфликтов программ нужно 
стремиться всегда передавать перехваченное 
управление исходному обработчику. Этого можно не 
делать только в том случае, если вашей задачей явля- 
ется как раз отмена обычной реакции на какое-то 


ІпР 09Н РНОС Гаг 


ризй ах 

; Сохранить регистр АХ. 

ІП 

аі , БОН 

; Ввести скан-код нажатой клавиши. 

стр 

аі, 1 

; Это клавиша Езс? 

Зе 

Езсргеззей 

а1,2В 


стр 

; Это клавиша Епіег? 

Зе 

ЕпРегргеззей 

- ; 

сгар 

а1,59 

; Эго клавиша Р1? 

3 е 

Р1_ргеззей 


рор 

ах 

: В противном случае восстановить 
[Іпі 09Н ѵеср] ; регистр АХ и 

Опір 

й»огй РТН сз: 

! 


передать управление исходному 

ёзс ргевзесі: 

5ІІ 


обработчику. 


саіі Езс_ргос ; Выполнить процедуру, 

рор ах ; Восстановить регистр АХ и передать 

^тр бяогб РТЕ сз:[ІпІ 09Н ѵесі] ; управление исходному 
: обработчику. 

ЁпІег_ргеззесі: 

ризЬГ : Вызвать исходный обработчик, 

саіі йиогб РТН сз: [ Іпр_09Н_ѵесІ] 


зіі 

саіі ЕпІег_ргос 
“ 


Выполнить процедуру. 

Восстановить регистр АХ и 
вернуться в прерванную программу. 


прерывание. 

Ниже приведен пример обработчика прерывания от 
клавиатуры, выполняющего некоторые действия при 
нажатии на одну из трех клавиш — Езс, Епіег и Р1. 
Действия задаются процедурами Е$с_ргос, Епіег_ргос 
и Р1_ргос, тексты которых опущены. При нажатии на 
клавишу Р1 исходный обработчик не получает управ- 
ления, т.е. эта клавиша полностью перепрограммиру- 
ется (пример полной замены старого обработчика). 
После этого вы уже не сможете воспользоваться под- 
сказкой, работая, скажем, с ЫоПоп Соттапбег (что, 
согласитесь, достаточно обидно). 


Р1 ргеззей: 

; Самостоятельно отработать 
іп а1,61Н 
ризіі ах 
ог аІ.ѲОН 
оиі 61Н,а1 
рор ах 
оиі 61Н, аі 


гаоѵ а1,20Н 
оиі 20Н,а1 


аппаратное прерывание. 

; Ввести байт из порта управления 
; клавиатурой и сохранить его. 

; Установить бит "подтверждение 
; ввода" и вывести байт в порт. 

; Записать в порт исходное значение. 
; Теперь контроллер клавиатуры 
обслужен и остается только 
; послать сигнал "конец прерывания" 

; контроллеру прерываний ШЕЬ 8259. 


зіі 

саіі Р1_ргос 



Выполнить процедуру. 

Восстановить регистр АХ и 
вернуться в прерванную программу. 


Іп1_09Н_ѵесІ йб ? 
ІпІ_09Н ЕГОР 


Здесь должен храниться старый 
вектор прерывания от клавиатуры. 
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Таблица 3 


Клавиша 

Последовательность 
скан-кодов (НЕХ) 

Клавиша 

Последова- 

тельность 

скан-кодов 

ЗузНец [1] 

54 

ЗЬі Рт+Іпзегі: 

ЕО 52 

Р11 

57 

ОеІеТе 

ЕО 2А ЕО 53 

Р 12 

58 

Ноте 

ЕО 2А ЕО 47 

ЯідЫ: АІГ 

Е0 38 

ЗНіРі+Ноте 

ЕО 47 

ЯідНТ СТг 1 

Е0 Ю 

Епсі 

ЕО 2А ЕО 4Р 

РгТЗс 

Е0 2А Е0 37 

ЗЫРГ+ЕпО 

ЕО 4Р 

ЗНіЕТ+РгТЗс 

Е0 37 

АггомІІр 

ЕО 2А ЕО 48 

СТгІ+РгТЗс 

Е0 37 

ЗНіРТ+Аггоѵ/ІІр 

ЕО 48 

АІТ+РгТЗс 


АггоѵѵОп 

ЕО 2А ЕО 50 

(ЗузРец) 

54 

ЗНіРТ+Аггоѵ/Оп 

ЕО 50 

Раизе [2] 

Е 1 10 45 Е1 ЭР С5 

РадеІІр 

ЕО 2А ЕО 49 

СТг І+Раизе 


ЗНіЕТ+РадеІІр 

ЕО 49 

(Вгеак) [2] 

ЕО 46 ЕО С6 

РадеЭп 

ЕО 2А ЕО 51 

ІпзегТ 

ЕО 2А ЕО 52 

ЗНіРТ+РадеОп 

ЕО 51 


Примечания : 

[1] Присутствует только на 84-клавишной клавиатуре АТ. 

[2] Не имеет скан-кода отпускания. 


Приведенный фрагмент нуждается в некоторых 
комментариях. Во-первых, это только иллюстрация. 
Реальный обработчик может потребовать выполнения 
дополнительных проверок — о них поговорим позже. 

Во-вторых, со стороны может показаться, что при 
обработке нажатия клавиш Езс и Епіег достигается 
один и тот же результат, но это не так. Между этими 
двумя примерами существует серьезное различие. При 
нажатии на клавишу Езс аппаратное прерывание 
отрабатывается только после завершения процедуры 
Езс_ргос. Поэтому в течение всей процедуры Езс_ргос 
прерывания запрещены. Команда зіі перед вызовом 
Езс_ргос не помогает. Прерывания разрешаются на 
уровне центрального процессора, но остаются запре- 
щенными на уровне контроллера прерываний. 

В-третьих, мы встретились здесь с новым поня- 
тием — скан-код клавиши. Не путайте его с АЗСІІ- 
кодом символа, соответствующего клавише. Скан- 
код — это байт, младшие семь битов которого содер- 
жат номер клавиши, а старший бит сообщает причину 
прерывания: 0 — клавиша нажата, 1 — клавиша 
отпущена. ВІ05 игнорирует скан-коды отпускания 
всех клавиш, кроме клавиш сдвига — $ЫН, Сігі и АИ. 
Скан-коды 83 клавиш стандартной клавиатуры ХТ 
приведены в таблице 2. 

Эти же скан-коды генерирует расширенная 101- 
клавишная клавиатура, используемая на большинстве 
современных машин, если вы работаете с ней через 
порт 60Н. Для дополнительных клавиш расширенной 
клавиатуры вырабатывается последовательность скан- 
кодов, т.е. прерывание происходит несколько раз при 
каждом нажатии или отпускании клавиши (см. таб- 
лицу 3). Не относитесь к информации, приведенной в 
таблице, слишком серьезно — для разных моделей 
клавиатур эти последовательности могут слегка разли- 
чаться. Важно, что они всегда содержат скан-код ана- 
логичной клавиши из основного набора. Воспользуй- 
тесь им и предоставьте ВІ08 разбираться с особенно- 
стями конкретной клавиатуры. Например, если рези- 
дентная программа использует скан-код 52Н, то она 


будет стартовать при нажатии как на 
клавишу Іпз, так и на клавишу Іцзегі. 
Для более подробного изучения скан- 
кодов можно воспользоваться про- 
граммой ЗСАИСООЕ текст которой 
приведен ниже. 

“Перехватить" прерывание — зна- 
чит изменить его вектор так, чтобы он 
указывал на ваш собственный обработ- 
чик. Перед этим следует прочитать и 
сохранить старый вектор на тот слу- 
чай, если потребуется обратиться по 
адресу исходного обработчика или 
восстановить прежнее значение век- 
тора. Вектор прерывания можно чи- 
тать и изменять, как и любую другую 
ячейку памяти, командой тоѵ, благо 
он всегда находится в определенном 
месте и адрес его рассчитать нетрудно. 
Однако документация по МЗ-ООЗ рекомендует при- 
менять для этого специальные функции с номерами 
25Н и 35Н. Перед началом чтения или изменения 
вектора необходимо запретить аппаратные прерыва- 
ния, чтобы исключить возможность модификации 
вектора в процессе чтения или возможность передачи 
управления по частично измененному вектору. 
Функции 25Н и 35Н обеспечивают это автоматически. 


Функция 35Н 

Получить вектор 

прерывания . 

Вызов : АН = 

35Н 


АІ_ - 

номер прерывания 


Возвращает : 

Е5:ВХ - указатель 

на программу 


обработки 

прерывания 


Функция 25Н. 

Установить 

вектор прерывания . 

Вызов : АН = 
АІ_ - 
63: ЭХ 

25Н 

номер прерывания 
- указатель на новую программу 
обработки прерывания 

Возвращает : 

— 



Следующий фрагмент демонстрирует изменение 
вектора прерывания от клавиатуры. 


тоѵ ах, 3509Н ; Прочитать вектор прерывания, 

іпі 21Н 

гаоѵ йога РТК ІпІ_09Н_ѵесІ,Ъх ; Сохранить вектор, 
тоѵ йога РТН Іпі_09Н_ѵесІ+2, ез 


гаоѵ 

ах,2509Н 

; Установить новый обработчик 

14з 

йх.Іпі; 09В 

; прерывания. 

іпі 

21Н 



Позаботьтесь, если требуется, о сохранении реги- 
стров АХ, ВХ, Е5 и Э5. 

Последнее замечание касается использования стека. 
Обычно обработчики прерываний “наследуют* 1 стек 
прерванной программы. Но будьте осторожны! Вы не 
можете определить глубину наследуемого стека, а его 
переполнение вызовет ошибку в прерванной про- 
грамме или даже зависание системы. Поэтому, если 
ваша резидентная программа интенсивно использует 
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стек, то лучше предусмотреть в ней собственный стек, 
например, следующим образом: 


Уоиг_Ьаіхі1ег РКОС Гаг 

ризЬ ах 
ризЬ Ьх 
ризЬ сх 
хог ах, ах 
Ьх, сз 
сх.зз 
Ьх, сх 

НапЫѳг_ЬосІу 
а!,1 


Сохранить регистры. 


тоѵ 
гаоу 
стр 

)е 
гаоѵ 
сП 
гаоѵ 
тоѵ 
гаоѵ 
тоѵ 
зіі 

Нап(Пег_Ьо<1у: 

ризЬ ах 


Обнулить АХ. 

Проверить сегмент стека, если он 
совпадает с сегментом кода (ухе 
испольауется внутренний стек), то 
не переключать стек. 

Установить признак переключения 
; стека и переключиться на 
■огб РТН сз:01б_5Іаск_роіп1;ег,5р ; внутренний 

нога РТН сз:01гі_зіаск_роігг1,ег+2,55 ; стек, 

зз, Ьх 

зр.ОКРЗЕТ 51аск_агѳа + 5І2Е 51аск_агеа 


Сохранить признак переключения стека. 


тело обработчика 

рорГ ; Проверить признак переключения стека. 

)пс Ко(,_сЬапёе 

сП ; Если нужно, то вернуться к старому 

тоѵ зр.иогб РТН сз:0іа_зіаск_роіп1ег ; стеку, 

тоѵ зз, »огй РТН сз:Оіа_зіаск_роіпЬег+2 
зП 

МоІ_сЬапее: 

рор сх ; Восстановить регистры, 

рор Ьх 
рор ах 
ігеЬ 

оіа_зЬаск_роіпіег аа ? 

5Ьаск_агеа а» 512 аир (?) 

Уоиг_Ьапаіег ЕГОР 

Если резидентная программа не допускает повтор- 
ной активизации в процессе своей работы, то можно 
исключить проверку при переключении стека (см. 
текст процедуры Ргераге в конце статьи). 


Как оставить программу 

резидентной в памяти 

При запуске программы на выполнение П08 нахо- 
дит свободную область памяти подходящего размера с 
наименьшим возможным адресом. В среде 
МЗ-ООЗ 4.x ЕХЕ-файлы с установленными в ноль по- 
лями максимально и минимально запрашиваемой па- 
мяти (в заголовке ЕХЕ-файла) загружаются по воз- 
можности в самые старшие адреса. В начале про- 
граммы создается префикс программного сегмента 
(Р8Р) размером 256 байт. Сама программа загружа- 
ется вслед за Р8Р. 

Кроме того, операционная система передает про- 
грамме копию среды. Среда БОБ представляет собой 
последовательность строк А8СІІ (переменных среды), 
завершаемых нулевым байтом. Формат этих строк 

ИМЯ = параметр 

Переменные среды П08 можно вводить и просмат- 
ривать с помощью команды 8ЕТ. Размер среды по 
умолчанию равен 160 байт для МЗ-ООЗ 3.3 и 
128 байт для предшествующих версий, но может быть 
увеличен до 32 Кбайт командой 5НЕ1Д. в файле С(Ж- 
РІС.ЗѴЗ. Сегментный адрес среды помещается в Р8Р 
по смещению 2СН. 


При запуске программы регистры процессора уста- 
навливаются следующим образом. 

В случае СОМ-файла: 

- СЗ, 05, Е5 и 35 указывают на Р5Р; 

- ІР = 100Н (конец Р5Р); 

- 8Р указывает на конец сегмента (содержит ОРРРЕН 
или меньше, если выделен не полный сегмент); 

- вся доступная память, в том числе память, занима- 
емая транзитной частью СОММАЫО.СОМ, выделя- 
ется программе. 

В случае ЕХЕ-файла: 

- ЭЗ и Е5 указывают на РЗР; 

- СЗ, 85, ІР и 8Р инициализируются значениями из 
заголовка ЕХЕ-файла. 

- для версий 003, предшествующих 4.0, вся доступная 
память также, как правило, выделяется программе. 

Всякая резидентная программа состоит из рези- 
дентной порции и кода загрузки. Код загрузки изме- 
няет значения используемых векторов прерывания и 
возвращает управление операционной системе, но па- 
мять, занимаемая программой, точнее ее резидентной 
порцией, не освобождается. Добиться того, чтобы про- 
грамма осталась в памяти, можно, завершив про- 
грамму обращением к прерыванию 27Н или к фун- 
кции 005 31 Н. 


Прерывание 27Н . Закончить, но сохранить 
в памяти . 

Вызов : С5 - 
ЭХ - 

сегментный адрес Р8Р 
смещение первого байта 
освобождаемой памяти 

Возвращает : 

— 


Функция 31Н 

Сохранить программу 

Вызов : АН = 
АІ_ - 

31Н 

код завершения (значение 


параметра ЕРРОВІ_ЕѴЕІ_ команды ІР . 
используемой в пакетных файлах), 
обычно - О 


ОХ - размер резидентной порции в пара- 
графах (блоках длиной 16 байтов) 

Возвращает : — 


В отличие от прерывания 27Н, функция 31 Н не 
требует загрузки в СЗ сегментного адреса РЗР, позво- 
ляет сохранять резидентными в памяти программы, 
размер которых превышает 64 Кбайт, и передавать 
код завершения родительскому процессу (обычно 
СОММАЫД.СОМ). При определении размера про- 
граммы для функции 31 Н не следует забывать о пре- 
фиксе программного сегмента (его длину нужно при- 
бавить к размеру резидентной порции). В целом, фун- 
кция 31 Н больше подходит для ЕХЕ-файлов, а в слу- 
чае СОМ-файлов удобнее пользоваться прерыванием 
27Н. Прерывание 27Н нельзя использовать для сохра- 
нения процедур обработки прерываний по критичес- 
кой ошибке и по СігІ+Вгеак. 
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Ниже на примере ЕХЕ-файла демонстрируется 
применение функции 31 Н. Предполагается, что про- 
грамма удовлетворяет стандартным соглашениям о по- 
рядке следования сегментов (сегмент стека — послед- 
ний). 

■ СОДЕ 

обработчики прерываний 

Вооі: ; Начало кода загрузки резидента. 

ПОУ йХ, Зр 

ризЬ бх 

изменить векторы прерываний. 

рор йх 
абб бх, 15 
гсг бх, 1 
тоѵ с1,3 
зНг бх.сі 

шоу ах, зз 
абб бх, ах 
тоѵ ах, ѳз 
зиЬ бх, ах 
тоѵ ах.ЭЮОН 
іпі 21Н 
ЭГО Вооі 

Резидентные программы размером более 64 Кбайт 
могут рассматриваться не иначе, как курьез. Поэтому 
резидентные программы обычно пишутся в формате 
СОМ-файла (как известно, программы в СОМ-форма- 
те всегда размещаются в одном сегменте памяти и, 
следовательно, имеют размер не более 64 Кбайт). Сле- 
дующий пример показывает, как использовать преры- 
вание 27Н в СОМ-файле. 

.моей. тот 

■ СОДЕ 
ОНС 100Н 

Епігу: )гар Вооі ; Перейти на код аагруэкн. 


Поскольку код загрузки используется только на 
этапе установки резидента, то, помещая его в конец 
программы, можно затем исключить его из резидент- 
ной порции, как это и сделано в последнем примере. 

Резидентные программы практически никогда не 
используют среду ЭОЗ, и вы можете освободить зани- 
маемую ею память функцией БОЗ 49Н. 


Функция 49Н 

Освободить область памяти. 

Вызов : АН = 
Е$ - 

49Н 

сегментный адрес освобождаемого 
блока памяти 

Возвращает : 

СР сброшен - ошибок нет 
СР установлен: 

АХ = 7 - разрушены блоки 

управления памятью 
АХ = 9 - неправильный сегмент 


Области памяти, освобождаемой с помощью фун- 
кции 49Н, должен предшествовать блок управления 
памятью (МСВ), который ЭОЗ создает при каждом 
распределении памяти. Блок управления памятью за- 
нимает 16 байт (один параграф) и имеет следующий 
формат: 


Смещение 

Длина 

Содержимое 

+ 0 

1 

тип ’М‘(40Н) - за этим блоком 
есть еще блоки МСВ; 
тип ’2'(5АН) - данный блок 
последний ; 

+ 1 

2 

владелец 

(сегментный адрес владельца); 

+ 3 

2 

размер (число параграфов 
в области памяти) ; 

+ 5 

11 

зарезервировано 
(не используется). 


; Определить размер стека в 
; параграфах. 


; Учесть размер предыдущих сегментов 
; и РЗР. 

; Е5 долхен указывать на Р3\ 

; Завершить программу, 

; сохранив ее в памяти. 


обработчики прерываний 

Вооі: ; Начало кода загрузки. Эта часть программы не является 

; резидентной. 

изменить векторы прерываний 


Чтобы освободить среду РОЗ, нужно вставить в 
программу такой фрагмент: 

тоѵ ез.иогб РТК ба:[2СН] ; Загрузить сегментный адрес 
гаоѵ аЬ,49Н і среды в регистр ЕЗ и освободить 

Іпі 21Н ; память. 


тоѵ бх.ОРГЗЕТ Вооі 
іпі 27Н 
ЭГО Епігу 


; Загрузить в БХ смещение первого 
освобождаемого байта. 

; Завершиться, оставив 
резидентную часть. 



Резидентная программа не нуждается и в РЗР, но с 
этим дело обстоит сложнее. Префикс программного 
сегмента нельзя освободить простым вызовом функции 
49Н (или функцией Ігеешеш языка С, использующей 
ее). Обратное утверждение В.Э. Дембского в статье 
“Резидентные программы на языке Си. Рекомендации 
разработчикам** (Интеркомпьютер, №5, 1990) оши- 
бочно. Для этого вам потребуется самим создать блок 
управления памятью в последних 16 байтах РЗР, за- 
тем изменить размер области памяти в МСВ, предше- 
ствующем РЗР. Только после этого можно будет вос- 
пользоваться функцией 49Н. В противном случае БОЗ 
освободит всю память, занимаемую программой. 
Правда, если вслед за этим вы сразу обратитесь к 
функции 31 Н или прерыванию 27Н, то ничего страш- 
ного не произойдет — операционная система не 
успеет перераспределить память и резидентная про- 
грамма не пострадает, однако она по-прежнему будет 
содержать РЗР, т.е. лишние 156 байт. 


2 Зак. 2661 
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ЭТОТ БЕЗУМНЫЙ, БЕЗУМНЫЙ, БЕЗУМНЫЙ МИР РЕЗИДЕНТНЫХ ПРОГРАММ 


Таблица векторов прерывания: 
ІпТ_09Н_ѵес1: : адрес обработчика 
ІпТ_16Н_ѵес1: : адрес обработчика 
Іп1:_21Н_ѵес1: : адрес обработчика 

прерывания 

прерывания 

прерывания 

09Н 

16Н 

21Н 

программы 

программы 

программы 

с. 

в. 

в. 

Программа А: 
ІпТ_09Н_ѵесі: : 
ІпТ_21Н_ѵесТ : 

адрес 

адрес 

обработчика 

обработчика 

прерывания 

прерывания 

09Н 

21Н 

ВІОЗ. 

003. 


Программа В: 
ІпТ_16Н_ѵест : 
ІпТ_21Н_ѵесТ : 

адрес 

адрес 

обработчика 

обработчика 

прерывания 

прерывания 

16Н 

21Н 

ВІОЗ. 

программы 

А. 

Программа С: 
ІпІ_09Н_ѵесТ : 

адрес 

обработчика 

прерывания 

09Н 

программы 

А. 

Рис. 1 . До удаления А 

Таблица векторов прерывания: 
ІпТ_09Н_ѵест : адрес обработчика 
ІпТ_16Н_ѵест : адрес обработчика 
ІпТ_21Н_ѵест : адрес обработчика 

прерывания 

прерывания 

прерывания 

09Н 

16Н 

21Н 

ВІОЗ. 

программы 

003. 

в. 

Программа В: 
Іп1:_16Н_ѵесТ : 
ІпТ_21Н_ѵесі: : 

адрес обработчика 
адрес обработчика 
(висячая ссылка). 

прерывания 

прерывания 

16Н 

21Н 

ВІОЗ. 

программы 

А 

Программа С: 
ІпТ_09Н_ѵест : 

адрес обработчика 
(висячая ссылка) . 

прерывания 

09Н 

программы 

А 


Рис. 2. После удаления А 


Учтите, блок управления памятью не документиро- 
ван, а значит, самостоятельная работа с ним связана с 
определенным риском. 

Вы можете воспользоваться другим программным 
трюком — переслать резидентную часть программы в 
Р8Р командой тоѵ$Ъ, уменьшив тем самым размер 
резидентной порции. В этом случае вам придется по- 
заботиться об изменении адресации (см. текст про- 
граммы ЗТТ в конце статьи). Прежде чем проделы- 
вать подобные вещи, внимательно изучите таблицу 
машинных кодов команд процессора и убедитесь, что 
вы понимаете разницу в кодировке команд передачи 
управления и работы с данными. Не забывайте также, 
что младшая часть Р8Р (до смещения 5СН) использу- 
ется БОЗ и в последний раз потребуется при выпол- 
нении функции 31 Н или прерывания 27Н (в даль- 
нейшем 008 будет использовать Р8Р прерванной про- 
граммы ) . 

Впрочем, надежнее просто найти применение Р8Р в 
резидентной программе. Например, использовать его 
как буфер ввода-вывода или разместить в нем соб- 
ственный стек. 

Как избежать повторной загрузки 

Итак, вы написали резидентную программу и бла- 
гополучно сохранили ее в памяти. Но что произойдет, 
если вы сами или другой человек, использующий вашу 
программу, забудет об этом и запустит ее повторно. 
Ответ очевиден — в памяти появится вторая копия 
резидентной программы. Потом третья, четвертая... 
Через некоторое время такой “забывчивый" пользова- 


тель может полностью исчерпать опе- 
ративную память. Разумеется, суще- 
ствует немало способов, с помощью 
которых человек, работающий за ком- 
пьютером, может определить, была ли 
Загружена конкретная резидентная 
программа. Однако хорошие про- 
граммы должны сами уметь это делать 
и сохраняться в памяти только в том 
случае, если не были загружены ранее. 

Эта задача не столь проста, как 
может показаться на первый взгляд. 
Например, сразу же напрашивается 
такая идея. Программа при попытке 
загрузки ее в память считывает вектор 
одного из используемых ею прерыва- 
ний и сравнивает фрагмент памяти, 
расположенный по этому адресу, с те- 
лом собственного обработчика. Если 
обнаружено совпадение, то программа 
уже загружена. 

Но такая простота обманчива. Ведь 
если совпадение не обнаружено, то это 
еще не значит, что резидентная про- 
грамма отсутствует в памяти. Просто 
вектор прерывания мог быть впослед- 
ствии изменен другой программой, 
загруженной поверх вашей. Следовательно, нужно 
найти какой-то более надежный способ избежать по- 
вторной загрузки. 

Рассмотрим два метода, которые, хотя и не лишены 
недостатков, часто используются в профессиональных 
программах. 

Первый способ заключается в применении какого- 
нибудь незадействованного прерывания или несуще- 
ствующей функции какого-либо прерывания. 

Так, ЫоПоп Сиібе для определения того, был ли он 
ранее загружен в память, помещает в АХ “магическое 
число" Р398Н и вызывает прерывание 16Н. Прерыва- 
ние ВІ08 16Н содержит набор функций для работы с 
клавиатурой. Номер функции задается содержимым 
регистра АН; функция с номером РЗН отсутствует. 
Ыогіоп Сиібе, оставаясь резидентным, перехватывает 
это прерывание. Его обработчик предусматривает, что 
если регистр АХ содержит Р398Н, то это значение за- 
меняется другим “магическим числом" — 6А73Н, по- 
сле чего осуществляется немедленный выход из пре- 
рывания. Таким образом, если после вызова прерыва- 
ния в регистре АХ находится 6А73Н, то Могіоп Сиібе 
уже загружен, а если любое другое значение, то его 
можно загружать. Правда, существует вероятность, 
что какая-нибудь другая программа воспользуется тем 
же прерыванием с тем же набором “магических чи- 
сел“, но эта вероятность пренебрежимо мала. 

Второй способ основывается на использовании так 
называемого мультиплексного прерывания, которое 
специально предназначено для взаимодействия с рези- 
дентными процессами самой ЭОЗ, такими как РКІЫТ, 
АЗЗІСИ и ЗНАКЕ. 
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Прерывание 2РН. Мультиплексное прерывание. 


Вызов: АН - номер мультиплексного процесса: 
01Н - резидентная порция РРІИТ; 

02Н - резидентная порция АЗЗІОЫ; 
ЮН - резидентная порция 5НАРЕ ; 

ОЗН - ОРН - зарезервированы; 

1 1 Н — 7РН - зарезервированы; 

80Н - РРН - доступны для процессов 
пользователя . 

АІ_ — номер функции (нас будет 

интересовать только функция 
ООН - дать статус 

установки процесса) . 


Возвращает: АІ. - статус установки: 

ООН - не установлен , 

можно устанавливать ; 
01Н - не установлен, 

нельзя устанавливать; 
РРН - установлен. 


Например, если вы присвоили своему процессу но- 
мер РОН, то обработчик прерывания 2РН может иметь 
такой вид: 

Іпі 2ГН РКОС Гаг 

стр ах, ОРОООН ; Если проверяется установка процесса 
)пе Раза 2РН ; с номером РОН, то запретить установку, 

тоѵ аІ.ОРРН ; в противном случае, передать 

; управление исходному обработчику. 

ігеі 
Раза 2РН: 

Зтр йиогб РТН сз: [ Іпі 2ГН ѵесГ] 

Іпі 2РН ѵесі йб ? 

ІПІГ2РН - ИГОР 

При загрузке наличие программы в памяти прове- 
ряется следующим образом: 
тоѵ ах,ОРОООН 
іпі 2РН 
стр а1,0 

)п 2 А1геайу_1пз1а11е<1 

если не установлен, то продолжить загрузку 

Вы можете назначить своему процессу любой номер 
из диапазона 80Н-РРН (в принципе, ничто не мешает 
использовать и номера 00Н-7РН). но если окажется, 
что какой-то другой резидентный процесс использует 
этот же номер, вы получите ложное сообщение о по- 
вторной загрузке. Поэтому желательно предоставить 
пользователю возможность изменять мультиплексный 
номер по собственному усмотрению, чтобы исключить 
конфликты с другими резидентными программами 
или, если потребуется, загрузить в оперативную па- 
мять несколько копий одной и той же программы. 

Остается добавить, что хотя, как утверждает Дан 
Роллинс, прерывание 2РН полностью определено уже 
для версии 3.2 М8-008, причем значительно шире, 
чем описано здесь, упоминание о нем отсутствует 
даже в документации по версии 4.x. Это, впрочем, не 
помешало использованию прерывания 2РН во многих 
программах, включая ТигЬо Неір, известный всем, кто 
работает с компиляторами фирмы Вогіапб. 


Как удалить резидентную 
программу из памяти 


Существует большое количество утилит, позволя- 
ющих удалять из памяти резидентные программы. Не- 
которые из них дают возможность просмотреть содер- 


жимое оперативной памяти и выбрать программы для 
удаления. Но можно и в самой резидентной программе 
предусмотреть возможность выгрузить ее, когда потре- 
буется. Для этого программа должна восстановить 
измененные ею вектора прерываний и освободить за- 
нимаемую память. 

Есть здесь, правда, небольшая тонкость. Чтобы яс- 
нее стала суть возникающей проблемы, рассмотрим 
такой пример. Пусть последовательно загружаются в 
память три резидентные программы — А, В и С. 
Предполагается, что программы написаны корректно, 
т.е. перед изменением вектора прерывания они сохра- 
няют адрес исходного обработчика, а затем вызывают 
его в процессе своей работы. Программа А перехваты- 
вает прерывания 09Н и 21 Н, программа В — преры- 
вания 16Н и 21Н, а программа С — прерывание 09Н. 
После этого программа А удаляется из памяти. На ри- 
сунках 1 и 2 показано содержимое соответствующих 
ячеек программ А, В, С и таблицы векторов прерыва- 
ния до и после удаления программы А. 

Нетрудно увидеть, что после удаления про- 
граммы А, программа С переходит в разряд “мусора". 
Она продолжает занимать место в оперативной па- 
мяти, но вызываться никогда не будет — при возник- 
новении прерывания 09Н управление сразу передается 
ВІ08. С программой В дело обстоит еще хуже. Она 
будет получать управление при возникновении преры- 
вания 16Н, но скорее всего не сможет правильно ра- 
ботать, так как потеряла контроль над прерыванием 
21 Н. Если же программа В попытается обратиться по 
адресу исходного обработчика прерывания 21 Н, 
например, для вызова какой-либо функции 008, то 
это почти наверняка приведет к зависанию операци- 
онной системы. 

Следовательно, прежде чем удалять резидентную 
программу, необходимо убедиться в том, что она нахо- 
дится на вершине списка обработчиков прерываний, 
или, другими словами, в том, что ни одно из прерыва- 
ний, используемых программой, не было впоследствии 
перехвачено другой программой. 

Следующий фрагмент позволяет выполнить все не- 
обходимые проверки и удалить, если можно, про- 
грамму А из памяти. 

Еетоѵе РКОС 
тоѵ сх, сз 

тоѵ ах, 3509Н ; Проверить вектор прерывания 09Н. 

іпі 21Н 

тоѵ еіх, ее 

стр сх, сіх 

Зпе 1(оІ_гетоѵе 

стр Ьх.ОРТЗЕТ ІпІ_09Н 

)пе Ноігепюѵе 

гаоѵ ах, 3521Н ; Проверить вектор прерывания 21Н. 

іпі 21Н 

тоѵ Пх.ез 

стр сх, йх 

Зпе КоР_гѳтоѵе 

стр Ьх.ОРРНЕТ ІПІ21Н 

Зе Шііпзіаіі 

НоІ_гегооѵе: 

геі 

Шііпзіаіі: 

ризЪ Йз ; Восстановить вектор прерывания 09Н. 
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ЭТОТ БЕЗУМНЫЙ, БЕЗУМНЫЙ, БЕЗУМНЫЙ МИР РЕЗИДЕНТНЫХ ПРОГРАММ 


тоѵ бх.жогб РТК ІпІ_09Н_ѵес1 
тоѵ бз.иогб РТК Іпі_09Н_ѵѳс1+2 
тот ах, 2509Н 
Іпі 21Н 
рор бз 

ризЬ бз ; Восстановить вектор прерывания 21Н. 

тот бх.иогб РТК ІпІ_21Н_ѵѳс1 

тот бз.иогб РТК ІпІ_21Н_ѵес1+2 

тот ах, 2521В 

Іпі 21Н 

рор бз 

сіі ; Освободить занимаемую память. 

ризЬ сз 

рор ез 

тот аЬ, 49Н 

іпі 21В 

геі 

Нетоте ЕГОР 

Для обращения к процедуре Кешоѵе можно приме- 
нить какое-либо незадействованное прерывание или 
несуществующую функцию какого-либо прерывания 
(как это делалось для предотвращения повторной за- 
грузки). При этом программа, запущенная со специт 
альным ключом, вместо того, чтобы оставаться рези- 
дентной, должна обращаться к означенному прерыва- 
нию, а обработчик прерывания — вызывать процедуру 
Кешоѵе. Возможно также использование для этой цели 
специальной “горячей" клавиши. 

В последнем случае вы рискуете столкнуться еще с 
одной проблемой, связанной с нереентерабельностью 
005. Но о том, в чем состоит эта проблема и как с 
нею бороться, будет рассказано в следующем разделе. 

А.Рыскунов 


; Программа ЭСАНСОВЕ (файл ЗС АКСОНЕ. АЗІ ) . 

; Перехватывает прерывание от клавиатуры, очищает экран и входит 
; в бесконечный цикл, выводя скан-коды нажимаемых клавиш 
; в шестнадцатиричном виде. Для прекращения работы программы 
; нужно нажать кнопку сброса Кезеі (перезагрузить систему). 

;* СоругіеЫ (с) Зепі Бапбу, 1991 
;• АЛЛ КІСНТЗ КЕ5ЕКѴЕВ 

.КОБЕЛ ТППГ 
• СОБЕ 
ОНО 100Н 

Епігу: 

)гар 5е1_Ьапб1ег 
Туре_Ьех РКОС поаг 

; Выводит символ из регистра АЛ на экран в позицию, определяемую 
; регистрами БН и БЛ, и увеличивает аначение Б!. 

ризЬ ах 
тоѵ аЬ,2 
іпі 10В 
рор ах 
тоѵ аЬ,9 
Іпі 10В 
іпс бх 

геі 

Туре_Ьех ЕГОР 
ІпІ_09Н РКОС Гаг 


ризЬ 61 
ризЬ зі 
ризЬ Ьр 

іп а1,60В ; Ввести скан-код нажатой клавиши. 

тоѵ аЬ.аІ ; Преобразовать скан-код 

апб ах.ОРООРН ; в два символа АЗС II. представляющих 

тоѵ с 1,4 ; его в шестнадцатиричном виде. 

зЬг вЬ.сІ 
абб ах.ЗОЗСШ 
стр аі , 58 
)Ь НехІ_ІезІ 
абб а!,7 
1(ехІ_Іе5І: 

стр аЬ, 56 
)Ь ТезІ_розі11оп 
абб аЬ, 7 

ТѳзІ_розі11оп: 

тоѵ бх.иогб РТК сз:РозШоп ; Если экран ааполнен, то 
стр 6Ь,25 ; очистить его. 

)Ь Туре_собе 
ризЬ ах 
тоѵ ах, ОЗН 
іпі ЮН 
хог бх, бх 
рор ах 
Туре_собе: 

тоѵ Ьх.ОЕН ; Вывести скан-код. 

тоѵ сх, 1 

ризЬ ах 

хсЬе аЬ.аІ 

саіі Туре_Ьех 

рор ах 

саі 1 Туре_Ьех 

тоѵ аІ.'Н' 

саіі Туре_Ьех 

тоѵ аі,' ' 

саіі Туре_Ьѳх 

стр 61,80 ; Если закончилась строка, то 

)Ь 5аѵѳ_розі11оп ; перейти к следующей. 

Іпс 6Ь 
хог 61, 61 
5аѵе_розіІіоп: 

тоѵ ѵогб РТК сз:Розі11оп,бх 

Іп а1,61Н ; Отработать аппаратное прерывание. 

ризЬ ах 

ог аі , 80Н 

оиі 61Н,а1 

рор ах 

оиі 61Н,а1 

тоѵ аі , 20Н 

оиі 20В, аі 

рор Ьр ; Восстановить регистры. 

рор зі 

рор бі 

рор бх 

рор сх 

рор Ьх 

рор ах 

ігеі 

Іп1_09Н ЕГОР 
Розіііоп б» О 
5е1_Ьапб1ег: 

тоѵ бх.ОЕРЗЕТ Іп1_09Н ; Перехватить вектор прерывания 
гаоѵ ах,2509Н ; от клавиатуры, 

іпі 21Н 

тоѵ ах, ОЗН ; Очистить экран. 

Іпі ЮН 

Яаі Ікеу: 

5Н0КТ Яаі1_кеу 
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Прошел почти год с тех пор, как мы узнали об Интеграторе “ Виктория “ — 
системной оболочке И08, созданной отечественными разработчиками. 

За это время программа стала широко известной — причем не только в нашей 
стране, но и за ее пределами. Проданы тысячи копий. Заключены дилерские 
соглашения с солидными фирмами — поставщиками программного обеспечения 
и вычислительной техники. Русская версия Интегратора “Виктория“ управляет 
персональными компьютерами на огромной территории — от стран Прибалтики 
до Дальнего Востока... Но что стоит за столь широкой популярностью? 

В чем секрет ВИКТОРИИ? Обо всем этом, а также о том, что предлагает 
нам вышедшая недавно новая версия программы — 1.8 — вы узнаете из данной 
статьи. 


Секрет ВИКТОРИИ 

Каковы слагаемые успеха? Как добиться удачи в та- Разве не повезло несказанно Биллу Гейтсу в том, 
ком стремительно меняющемся бизнесе, как произвол- что он в момент бурного развития вычислительной 
ство программного обеспечения? Говорят, для дости- техники оказался в той самой стране равных возмож- 
жения успеха нужно лишь чуточку везения: надо про- ностей, где оно, это развитие, и происходило, и во- 
сто в нужное время оказаться в нужном месте. Что, не время сообразил, чем ему следует заниматься? Ска- 
верится? Давайте посмотрим... жете, не он один сообразил. Действительно, не он 
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СЕКРЕТ ВИКТОРИИ 


один. В то время появилось множество крошечных 
фирм, пытающихся втиснуться в эту, пока еще сво- 
бодную нишу рынка и предлагающих массу разнооб- 
разных программных товаров и услуг: от компьютер- 
ных игр и средств обработки данных до серьезных 
промышленных и деловых программ. И ведь только 
подумайте, какая потрясающая возможность для ум- 
ных людей! Исключительно силой собственного ин- 
теллекта сделать такое огромное и полезное для чело- 
вечества дело, ну и, конечно, заработать себе на про- 
питание. Естественно, такие люди нашлись. Тогда по- 
явились и МісгозоН, и Вогіапб, и 2оПесН, и легендар- 
ный Питер Нортон, и прочие известные и уважаемые 
сегодня люди и фирмы. 

Почему именно они, а не другие? На самом деле на 
их месте мог оказаться кто угодно. Просто именно эти 
люди смогли предвидеть, почувствовать тенденции 
развития мировой индустрии, ну а дальше — уже дело 
естественного отбора. 

Выходит, помимо простого дурацкого везения, для 
достижения успеха в бизнесе нужно еще и хорошо со- 
ображать (хотя, наверное, это никогда не вредно). 

Возможно ли все это в нашей стране? Нет никаких 
сомнений — возможно! Ведь по количеству умных и 
предприимчивых, а главное — голодных людей мы 
опережаем все страны мира, вместе взятые. А как 
известно, голод — не тетка... 

Как появилась "Виктория" 

«Идея создания “Виктории" возникла у меня еще в 
конце восьмидесятых годов, когда я занимался разра- 
боткой АРМов и САПРов на одном из наших 
“многопрофильных* 4 предприятий, — рассказывает 
Виктор Ковалев, автор оболочки. — Тогда мы впервые 
увидели Ыогіоп Сошшапйег, который потряс нас своим 
могуществом и простотой. Но сразу стало ясно, что в 
деле создания АРМов Ыогіоп Соттапсіег — не по- 
мощник. Не хватало у него гибкости в работе с фай- 
ловыми системами дисков, нельзя было запрограмми- 
ровать необходимые технологические операции. Тогда- 
то и появился мой первый конструктор меню, поло- 
женный в основу нынешнего Интегратора». 

Добавим, что у первого Интегратора не было ко- 
мандно-файлового процессора, и был он совсем не по- 
хож на достопочтенный ИоНоп Соттапбег. Вся кра- 
сота идеи заключалась в том, что при помощи про- 
стейшего макроязыка, включавшего лишь пару управ- 
ляющих спецсимволов, можно было существенно рас- 
ширить возможности ООЗ и ее ЬаІсЬ-файлов. А гиб- 
кий конструктор меню, позволявший связывать созда- 
ваемые командные цепочки единым (и удобным!) 
пользовательским интерфейсом, довершал целостность 
строения. 

Между прочим, среди известных зарубежных про- 
грамм до сих пор не слышно о конструкторах меню, 
обладающих возможностями “Виктории**. Почему-то 
простая идея возложить на оболочку системы меню 


организацию наглядного интерфейса с пользователем 
не пришла никому в голову. В лучшем случае подоб- 
ные программы предлагают подстановку аргументов в 
команды, аналогичную подстановке аргументов через 
фиктивные параметры %1-%9 в ЬаісЬ-файлах. Пожа- 
луй, единственное исключение — системная оболочка 
ХТгее Рго Соісі, которая позволяет выбирать файлы, 
подставляемые в команды меню, при помощи курсора 
с панели директории. Во всех других программах 
запрос аргументов для подстановки в команду идет на 
уровне их ручного ввода, что, естественно, не 
слишком удобно. 

Вот с макрокомандами дело обстоит получше. Поль- 
зовательские макрокоманды предлагаются сегодня 
многими системными оболочками. Интересно, что в 
недавно вышедшей МЗ-ООЗ 5.0 появилась утилита 
ООЗКЕУ, также позволяющая создавать пользователь- 
ские макрокоманды (что, кстати, говорит о назревшей 
необходимости предоставления подобного сервиса уже 
на уровне операционной системы). 

Интегратор “Виктория** решил все проблемы под- 
становки аргументов в команды меню просто и кра- 
сиво. В итоге появилась возможность почти полностью 
отказаться от использования командно-файлового про- 
цессора в повседневной рутинной работе (до тех пор, 
пока не возникает потребность скопировать файлы на 
дискеты или с дискет). Вместо этого можно при по- 
мощи пользовательских меню запрограммировать всю 
технологическую цепочку запуска необходимых в ра- 
боте прикладных программ с наглядной и удобной 
подстановкой аргументов в них. 

Не хотите пользоваться меню? Пожалуйста! Можно 
запускать свои программы при помощи тех же макро- 
команд, вызываемых нажатием “горячей** клавиши, 
либо просто из командной строки. Везде поддержива- 
ется возможность гибкой подстановки аргументов в 
команды. Однако по опыту работы можно утверждать, 
что пользовательские меню Интегратора “Викто- 
рия“ — самый удобный способ запуска любых прик- 
ладных программ. 

Что умеет "Виктория” 

Для тех, кто не читал нашей предыдущей статьи об 
Интеграторе “Виктория** , кратко перечислим основ- 
ные компоненты и возможности системы с указанием 
тех, что появились в версии 1.8. 

Интегратор "Виктория" представляет собой со- 
четание развитой системы конструирования пользова- 
тельских меню и мощного командно-файлового про- 
цессора. Это позволяет создавать (интегрировать) из 
разнородного программного обеспечения законченные 
технологические системы (АРМы), доступные в экс- 
плуатации даже неподготовленным пользователям. 
Оболочка Интегратора “Виктория** содержит обшир- 


* См. КомпьютерПресс №6, 1991. 
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ный набор сервисных функций, часто используемых 
при работе с компьютером, что избавляет 
пользователя от необходимости обращаться за допол- 
нительным сервисом к другим служебным программам. 

Конструктор меню Интегратора “Виктория" под- 
держивает не только иерархические связи типа 
“меню-подменю“, но и перекрестные ссылки (сетевые 
связи), в том числе рекурсивные вызовы, эмулиру- 
ющие циклы процедурных языков. Реализована воз- 
можность анализа структуры и визуализации дерева 
системы меню пользователя, а также перехода по де- 
реву в любое меню системы (версия 1.8). Предусмот- 
рены развитые средства для поддержки системы меню 
разнообразными подсказками, аннотациями и доку- 
ментацией. 

При выборе пункта меню реализуется переход в 
подменю и/или выполнение заданной последователь- 
ности команд, включая расширенные команды файло- 
вого процессора. Разработчику предоставляется воз- 
можность гибкой организации запроса аргументов лю- 
бой процедуры, в частности: 

- возможность ввода аргументов в диалоге; 

- возможность подстановки в команду имени файла, 
выбираемого пользователем из списка файлов теку- 
щей директории; 

- возможность подстановки в команду имен файлов, 
выбираемых пользователем из предварительно 
отфильтрованного списка файлов (версия 1.8); 

- возможность выбора аргументов по их мнемоничес- 
ким именам из специального файла аргументов. В 
этом случае пользователь видит не собственно аргу- 
менты, а меню с соответствующими им именами, из 
которых следует сделать выбор. Таким образом, на- 
пример, вместо имени выбираемого файла может 
фигурировать название документа, который содер- 
жится в данном файле. Существенно, что пользова- 
тель-новичок при работе с меню может даже не 
подозревать о существовании сложной файловой 
системы. 

Имеется возможность подключения альтернативных 
(независимых) систем пользовательских меню 
(например, индивидуальных для каждого пользова- 
теля), число которых не ограничено. Переход из одной 
системы пользовательских меню в другую и обратно 
может осуществляться через выполнение пункта меню 
или одной из макрокоманд оболочки. 

Организована возможность обмена сообщениями 
между пользователями на уровне системы меню или 
любого подменю системы. 

Командно-файловый процессор Интегратора 
“Виктория" обладает удобным, интуитивно понятным 
интерфейсом, выполненным с учетом устоявшихся 
требований к оболочкам 008. Имеется развитая си- 
стема контекстно-чувствительной помощи. Все это по- 
зволяет пользователям-новичкам быстро освоиться в 
среде “Виктория", а у более опытных пользователей 
процесс адаптации проходит практически мгновенно. 


Помимо традиционных функций оболочек ЭОЗ, 

Интегратор “Виктория" предлагает целый ряд расши- 
ренных возможностей, например: 

- возможность создания до 30 макрокоманд пользова- 
теля (дополнительных функций), непосредственно 
выполняемых при нажатии функциональных клавиш 
5НІН/СІГІ/АН+Р1...Р10. Для любой из систем поль- 
зовательских меню или отдельных пользователей на- 
бор макрокоманд может быть индивидуальным; 

- возможность переустановки системных параметров 
005 (8ЕТ и РАТН) без выхода из среды “Виктория" 
и без перезагрузки операционной системы; 

- возможность выделения (отметки) файлов как без 
записи, так и с записью на диск (версия 1.8). В по- 
следнем случае файлы могут быть выделены не 
только в текущей директории, но и на разных логи- 
ческих устройствах, при этом отметка файлов сохра- 
няется после выключения компьютера; 

- выполнение любой операции над группой выделен- 
ных файлов (вы можете, например, выбрать файлы, 
затем одной командой оттранслировать или заархи 
вировать их); 

- при вводе командной строки можно использовать 
разделитель команд (для ввода нескольких команд в 
одной командной строке), осуществлять автомати- 
ческую подстановку имен группы выделенных фай- 
лов или имени текущего файла в качестве аргумен- 
тов команды ( расширенные команды файлового про- 
цессора)-, 

- история выполненных команд появляется автомати- 
чески при вводе командной строки и сохраняется по- 
сле выключения компьютера. Любую из команд 
можно отредактировать или удалить из истории ко- 
манд; повторяющиеся команды отслеживаются и не 
дублируются. История команд может быть индивиду- 
альной для каждого пользователя системы; 

• при обработке файла по его типу (расширению) 
можно использовать целый набор команд, в том 
числе групповые операции. Для любых команд 
можно задать функциональные клавиши (РЗ, Р4 или 
Епіег), по нажатии которых будут выполняться эти 
команды. Это дает возможность подключения к си- 
стеме до 50 альтернативных редакторов, форматиро- 
ванных файловых визуализаторов и прочих программ 
обработки, связанных с конкретным файловым рас- 
ширением. Для различных систем пользовательских 
меню или разных пользователей возможен разный 
набор подключенных программ; 

- возможность поиска файлов с использованием маски 
имени и одновременно поискового контекста по 
всему логическому диску, по текущей директории, по 
директории с вложенными поддиректориями и по за- 
писанной на диске выборке файлов (отмеченным 
файлам). В дальнейшем можно сохранить и допол- 
нить список найденных файлов, а также производить 
с ним разнообразные операции: исключать из списка 
ненужные файлы, просматривать и редактировать 
файлы списка, копировать, перемещать и удалять на 
диске выбранные из списка файлы (версия 1.8); 
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- возможность копирования, перемещения и удаления 
директорий со всеми входящими в них файлами и 
поддиректориями; 

- возможность копирования файлов больших размеров 
с разбивкой их на несколько дискет; 

- возможность восстановления удаленных файлов 
(версия 1.8); 

- форматирование дискет; 

- тренажер клавиатуры; 

- возможность настройки цветовой палитры 
“Виктории" в соответствии со вкусом пользователя и 
многое, многое другое! 

Система авторизации Интегратора “Виктория" 
представляет собой трехуровневую иерархическую си- 
стему паролей, позволяющую защитить от несанкци- 
онированного доступа или модификации как всю си- 
стему пользовательских меню, так и отдельные меню 
и пункты. Смена файловых атрибутов в “Виктории" 
доступна только авторизованным пользователям. За- 
щищенные файлы не могут быть модифицированы 
или удалены средствами “Виктории". Простейшим, но 
весьма эффективным способом защиты является за- 
прет отображения скрытых и системных файлов и ди- 
ректорий на рабочих панелях “Виктории". Система 


авторизации позволяет также запретить пользователю 
работу с командно-файловым процессором и выход в 
008. Для каждой независимой системы пользователь- 
ских меню система авторизации может быть уникаль- 
ной. 

Архивная оболочка Интегратора “Виктория" ре- 
ализует все функции архиваторов (упаковка, распа- 
ковка, создание самораспаковывающегося архива) в 
режиме эмуляции директории. Это позволяет пользо- 
вателю работать с архивным файлом так же, как с 
обычной директорией. На панели архивного файла 
отображаются все упакованные файлы и директории с 
поддиректориями. Архивация файлов и модификация 
архивов осуществляются обычными операциями копи- 
рования, перемещения и удаления. При создании са- 
мораспаковывающегося архивного файла размер его не 
ограничивается объемом ОЗУ. 

Технические характеристики . 

Интегратор “Виктория" работает на ІВМ-совмести- 
мых персональных компьютерах с видеоадаптерами 
Негсиіез, ЕСА, УСА. 
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Операционная система 
Необходимый объем 
оперативной памяти 
Необходимый объем 
дисковой памяти 
Размер резидентной части 


БОБ 3.0 или старше 

не менее 384 Кбайт 

около 300 Кбайт 
2,9 Кбайт или 13 Кбайт 


Полная поддержка работы с мышью. Возможна 
эмуляция графического курсора мыши на текстовом 
экране. 

Интегратор “Виктория" является системой с 
высокой степенью защищенности от неадекватных 
действий пользователя. При выполнении любых опе- 
раций, связанных с возможностью потери данных 
(таких как удаление файлов, копирование, перемеще- 
ние или удаление директорий с вложенными подди- 
ректориями), система требует от пользователя повтор- 
ного подтверждения. Для наиболее ответственных 
операций предусмотрена автоматическая отмена опе- 
рации, если подтверждение на выполнение не посту- 
пило в течение определенного промежутка времени 
(около 2 с). 

Интегратор “Виктория" обеспечивает защиту своих 
основных модулей от инфицирования компьютерными 
вирусами. Это избавляет пользователя от характерной 
для многих системных оболочек катастрофической си- 
туации, когда вирус прикрепляется к резидентному 
Исполнительному модулю и заражает впоследствии все 
программы. 


"Виктория" 1.8. Что нового? 


Остановимся более подробно на новых возможно- 
стях версии 1.8. 

Во-первых, полностью переписан основной рези- 
дентный модуль программы. Теперь в комплект по- 
ставки включены два его варианта — ѴІ5МАІХ.ЕХЕ 
размером 2,9 Кбайт и ѴІ.ЕХЕ размером 13 Кбайт. 

Безусловно, использование ѴІ5МАЫ..ЕХЕ предпо- 
чтительнее. Кстати, при запуске оболочки с помощью 
этой программы имеется возможность изменять пере- 
менные среды 003 не только из командной строки, 
командой пользовательского меню или клавиатурной 
макрокомандой (как у ѴІ.ЕХЕ), но и при помощи 
ЬаісН-файлов (так, как это можно делать в самой 
БОЗ). 

Программа запуска ѴІ.ЕХЕ может оказаться полез- 
ной в случае непредвиденных осложнений с ѴІ5- 
МАЬБ.ЕХЕ. Дело в том, что в своей работе ѴІ8- 
МАЬЬ.ЕХЕ использует недокументированные внутрен- 
ние прерывания 003, которые в принципе могут быть 
изменены разработчиками операционной системы. 
Однако не стоит излишне беспокоиться о совместимо- 
сти “Виктории" (а точнее, ее программы запуска 
ѴІ5МАІХ.ЕХЕ) с вашим компьютером. С версиями 
003 3.x, 4.x, 5.0 оболочка работает надежно. 

Во-вторых, в значительной степени изменена иде- 
ология построения управляющих меню оболочки 
(меню, “выпадающих" из верхней строки экрана и со- 


держащих команды вызова сервисных функций Интег- 
ратора). Помимо того, что изменились названия и со- 
держание некоторых меню (добавлены новые ко- 
манды), поменялись и клавишные комбинации вызова 
этих меню, а также быстрые клавиши вызова часто 
используемых команд. Теперь во всех клавишных 
комбинациях применяются только русские управля- 
ющие символы, подобранные в соответствии с мнемо- 
никой команд (кстати, при этом не обязательно пере- 
ходить на русский алфавит). Безусловно, переучива- 
ние при переходе со старой версии на новую вызовет 
некоторые трудности, однако, как показывает прак- 
тика, для отечественных пользователей такое усовер- 
шенствование весьма существенно. 

Переработаны и улучшены многие функции. В 
частности, значительно усовершенствована функция 
контекстного поиска файлов. Теперь поиск возможен 
не только по всему диску, по текущей директории, по 
текущей директории с вложенными поддиректориями, 
но также и по записанной на диске выборке файлов. 
Как и в предыдущей версии, список найденных фай- 
лов может быть сохранен, в него могут быть добав- 
лены новые файлы или исключены ненужные. Новой 
в версии 1.8 стала возможность работы со списком 
найденных файлов, как с самостоятельной панелью 
директории: можно копировать, перемещать и удалять 
на диске выбранные из списка файлы точно так же, 
как при работе с обычной директорией (очень полез- 
ная возможность!). 

В отличие от предыдущих версий, “Виктория" 1.8 
поддерживает как фиксированную отметку файлов (с 
записью на диск), так и виртуальную отметку 
(выбранные файлы “живут" только в пределах теку- 
щей панели). Предусмотрены режимы ручной или ав- 
томатической фиксации выбранных файлов на диске. 

Добавлена функция восстановления стертых файлов 
и директорий. Имеется возможность автоматического 
и ручного восстановления. 

Предусмотрено переключение курсора мыши из 
псевдографического, в виде стрелки (эмуляция графи- 
ческого курсора мыши на текстовом экране), в обыч- 
ный текстовый — в виде подсвеченного блока. 

Одним из главных и наиболее интересных усовер- 
шенствований стал новый способ подстановки аргу- 
ментов в команды пользовательских меню. В вер- 
сии 1.7 имелась возможность ручного ввода аргумен- 
тов по запросу, подстановки в команду имени текуще- 
го файла с панели директории и возможность выбора 
аргументов по их мнемоническим именам из заранее 
составленного файла аргументов. Последний способ 
достаточно интересен, поскольку он позволяет при ра- 
боте с меню практически полностью забыть о сущест- 
вовании операционной и файловой системы. Однако 
здесь пользователь ограничен только фиксированны- 
ми, заранее определенными аргументами. 

В “Виктории" 1.8 остались все перечисленные спо- 
собы подстановки, и к ним добавился еще один. Те- 
перь существует возможность подстановки в качестве 
аргументов имен файлов, выбираемых пользователем 
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из предварительно отфильтрованного списка файлов. 
Этот список автоматически формируется из тех фай- 
лов текущей директории, имена которых соответ- 
ствуют указанной в команде маске имени. 

Например, в команде запуска текстового процессора 
\ѴОК.О вы можете указать маску *.бос. При выполне- 
нии пункта меню с этой командой на экран будет вы- 
веден список всех файлов текущей директории с рас- 
ширением .БОС. Из этих файлов можно курсором вы- 
брать документ, предназначенный для редактирования. 
Если нужный файл в списке отсутствует, или вы хо- 
тите начать редактировать новый документ, можно 
вместо выбора файла из списка ввести его имя вруч- 
ную. Любой запрашиваемый аргумент может быть 
также пропущен. 

При работе с системой меню предусмотрена удо- 
бная возможность маскирования имен файлов панели 
директории. Для каждого 
из пользовательских меню 
может быть определена 
маска, в соответствии с 
которой на панели дирек- 
тории будут отображаться 
файлы. Так, задав маску 
*.*, вы получите на пане- 
ли список всех файлов те- 
кущей директории без ее 
поддиректорий; задав мас- 
ку *.ехе — список всех 
файлов с расширением 
.ЕХЕ и т.д. Поскольку су- 
ществует возможность за- 
претить пользователю пе- 
реход из меню на панель 
директории и работу с ко- 
мандно-файловым процес- 
сором, можно ограничить 
доступ конкретного поль- 
зователя к ненужной ему 
информации. 

И, наконец, реализова- 
на великолепная возмож- 
ность перехода по дереву меню в любое пользователь- 
ское меню подключенной системы. Правда, если ваша 
система меню заблокирована паролем, то такие пере- 
ходы будут доступны только администратору системы. 

Усовершенствована не только оболочка в версии 
1.8. В нее включены дополнительные утилиты, пред- 
ставляющие собой самостоятельные приложения 
“Виктории**. Среди них утилита “Документ**, предо- 
ставляющая удобный интерфейс (по сути, базу дан- 
ных) для работы с разнообразными деловыми докумен- 
тами, письмами и бланками. В комплект “Виктории** 
1.8 вошли также утилиты русификации компьютера, в 
том числе редактор драйвера раскладки клавиатуры. 

В версии 1.8 полностью переработана документа- 
ция. Объем ее увеличился примерно втрое. Все воз- 
можности “Виктории** описаны очень подробно; при- 
ведено много полезных примеров. 


В чем секрет ВИКТОРИИ 

Итак, в чем же секрет ВИКТОРИИ? Почему 
именно эта оболочка пользуется наибольшим коммер- 
ческим успехом в нашей стране, несмотря на наличие 
и широкое распространение таких превосходных про- 
грамм, как Могіоп Соттапбег, РС Тооіз и прочих, в 
том числе отечественного производства? 

Пожалуй, стремительный рост популярности 
“Виктории** обусловлен тем, что авторам удалось со- 
единить в программе два важнейших качества — гиб- 
кость и простоту. 

Интегратор “Виктория" предоставляет неограни- 
ченные возможности по своему наращиванию. Сама 
“Виктория** предлагает только основной (хотя и очень 
обширный) сервис для работы' с файловой системой, а 
также интерфейс пользовательских меню. Далее вы 

можете “по кирпичику** 
строить свою собственную 
оболочку. Сюда могут 
войти и клавишные мак- 
рокоманды, и развитые 
функции обработки фай- 
лов по расширению, ну и, 
конечно, пользовательские 
меню, позволяющие за- 
программировать всю не- 
обходимую технологичес- 
кую цепочку запуска при- 
кладных программ. При 
этом “Виктория** не огра- 
ничивает пользователя 
только одной системой 
меню или одним набором 
макрокоманд. В процессе 
работы существует воз- 
можность оперативного 
подключения альтернатив- 
ных (независимых) сис- 
тем пользовательских ме- 
ню, причем делается это 
“на ходу**, совершенно 
незаметно для пользователя. Кроме этого, “Виктория** 
предоставляет каждому пользователю возможность 
иметь свою собственную конфигурацию системы, 
подключаемую, например, при переходе в меню 
конкретного пользователя. Здесь может быть и незави- 
симый набор клавиатурных макрокоманд, и соб- 
ственный набор операций обработки файлов по рас- 
ширению, и собственная история введенных команд, и 
даже собственная раскраска и прочие настройки кон- 
фигурации оболочки. 

Интегратор “Виктория** очень прост в использова- 
нии. Все операции интуитивно понятны. Имеется си- 
стема контекстно-чувствительной помощи. Для разра- 
батываемых систем пользовательских меню возможно 
создание собственной контекстно-чувствительной по- 
мощи, основанной на подсказках и аннотациях к пун- 
ктам меню, а также документации к отдельным меню 
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и системе в целом. Пользовательские меню Ин- 
тегратора “Виктория" берут на себя всю работу по за- 
пуску прикладных программ, запросу и подстановке 
аргументов в команды. При этом на экран выдаются 
списки возможных аргументов или опций в понятном 
пользователю виде (любые аргументы и опции могут 
быть представлены мнемоническими именами), из ко- 
торых делается выбор. 

При всем обилии возможностей “Виктория" весьма 
компактна: версия 1.8 занимает на диске всего лишь 


около 300 Кбайт. Вместе с интерфейсом на русском 
языке, гибкостью и простотой в использовании Интег- 
ратор “Виктория" является прекрасной системной 
оболочкой для вашего персонального компьютера. 

С. Александров 

Производитель Интегратора “Виктория": научно- 

производственная фирма “ИнФоС". 

Цена версии 1.8 — 2000 руб. 


Фирма МісгозоГі объявила 
о том, что ведет работы над 
\Ѵіп32з — интерфейсе при- 
кладных программ (АрІ), ко- 
торый позволит разработчи- 
кам писать программы на С 
и С++, которые будут с оди- 
наковым успехом работать 
как под ЛѴіпбоѵго 3.1, так и 
под 'ѴѴіпдоадч №Г. Програм- 
мы, написанные с примене- 
нием \Ѵіп32$, будут работать 
и подо всеми будущими 
1 6-разрядными версиями 
АѴіпсіолѵя. 

\Ѵіп32$ позволит одновре- 
менно выпускать на рынок 
продукты и для 3.1, под 
\Ѵіги1о>ѵз Ш\ 

ИеѵіЬуІе^ Аев'х Ыеіѵ/огк., 
МагсН 6, 1992 


Начались поставки элект- 
ронного словаря “Кон- 
текст 1.0“, разработанного 
фирмой “Информатик”, для 
переводов текстов при работе 
на ІВМ РС-совместимых 
персональных компьютерах. 
По традиции фирмы, сло- 
варь представляет собой ре- 
зидентную программу, сов- 
местимую практически с 
любым текстовым про- 
цессором, работающим в 
текстовом режиме. В их чис- 
ло входят М3 \ѴогсІ, \ѴогсГ 
Регіесі, МиШ-ЕсМ, Ргаше- 
мгогк, ЛѴогсІЗіаг и другие. 
Поставка словаря может 
включать общий англо- 
русский и русско-английс- 
кий словарь на 35 тысяч 
слов, англо-русский и рус- 
ско-английский словарь ком- 
пьютерных терминов на 
10 тысяч слов, словарь рус- 
ских синонимов на 30 тысяч 
слов и выражений. Програм- 
ма понимает отдельные сло- 
ва, идиомы, устойчивые сло- 
восочетания, фразеологизмы. 


Полный комплект зани- 
мает на диске около 
2.6 Мбайта. Со всеми слова- 
рями “Контекст 1.0“ стоит 
4990 рублей. Телефон для 
справок 299-99-04. 

Ком пьютерПресс, 
11 марта, 1992 


Растут продажи новой 
версии всемирно известного 
издательского пакета Ѵепіига 
РиЫізЬег 4.0. Пакет работает 
в среде М3 ѴПпдо\ѵ$ и актив- 
но использует возможности 
этой среды. Эта версия не 
будет выпускаться для рабо- 
ты в средах МЗ-ЭОЗ и СЕМ. 

Ѵепіига РиЫізНег 4.0 име- 
ет много новых интересных 
возможностей. Обеспечива- 
ется поддержка 65 000 цве- 
тов для закраски плашек, в 
том числе возможен выбор 
цветов и растров из каталога 
РАШЧЖЕ. 

Пакет полностью поддер- 
живает операции подготовки 
изображения и цветоделе- 
ния, правда для этого при- 
дется приобретать дополни- 
тельные модули, которые 
могут утроить цену пакета. 
Можно применять 24-битные 
цветные изображения в фор- 
матах ЕРЗ, ТІРР и РСХ. 

Добавлены функции ра- 
боты с текстом, в том числе 
поиск/замена, программа 
проверки орфографии, что 
позволяет не возвращаться в 
текстовый процессор, если в 
тексте что-то не так. 

Единственный недоста- 
ток — Ѵепіига 4.0 существу- 
ет только в английской вер- 
сии. Остается надеяться, что 
со временем появится и 
русская, 

КомпьютерПресс, 
11 марта, 1992 


Сообщается о появлении 
нового компьютерного виру- 
са. Вирус проникает в ком- 
пьютер при соединении с 
удаленным компьютером че- 
рез модем. Действие вируса 
проявляется ночью, причем 
поражается не только ком- 
пьютер, но и человек, рабо- 
тающий за ним. 

Основные симптомы по- 
ражения компьютера: крас- 
ный индикатор работы дис- 
ковода постоянно светится 
зеленым светом (соответст- 
венно зеленый индикатор 
светится голубым светом) ; 
мышь начинает танцевать на 
клавиатуре; монитор враща- 
ется вокруг своей оси со ско- 
ростью 200 об/мин; все кни- 
ги, лежавшие рядом с кла- 
виатурой, утрачивают часть 
информации, некоторые 
символы мерцают; не удает- 
ся выключить компьютер с 
помощью сетевого выключа- 
теля, также не помогает вы- 
дергивание из розетки; мо- 
дем автоматически устанав- 
ливает соединения с девуш- 
ками и треплется с ними из- 
рядное время; не работает 
клавиатура (вы можете на- 
жать клавишу, но в резуль- 
тате в компьютер передается 
бранное слово) . Компьютер 
полностью перестает функ- 
ционировать через три дня 
после заражения — все мик- 
росхемы выскакивают из 
своих панелек и остаются 
лежать недвижимыми вокруг 
компьютера. При попытке 
включения на дисплей выво- 
дится надпись: “Не 

влезай — убьет!!!“ 

Основные симптомы 
поражения пользователя: 
сильная головная боль (ас- 
пирин и тройчатка не помо- 
гают) , ночные кошмары и 
галлюцинации. Пользова- 
тель полностью перестает 


функционировать через 
20 минут. Будьте внима- 
тельны и постарайтесь убе- 
речься от заражения! 

РЮОпеІ, 
Аргіі 1, 1992 


Вероятность удара вируса 
Микеланджело вызвала 
большое число публикаций в 
американской прессе — мо- 
жет быть, даже слишком 
большое. 

За неделю до 6 марта — 
дня активации вируса — о 
нем писали Ые\ѵ Ѵогк Оаііу 
Ыеѵѵз на первой полосе, ему 
было .посвящено полвыпуска 
АВС-ТѴ “Мі 8 Ы1іпе 5Но\ѵ,“ 
части программ АВС-ТѴ 
“СооО Мотіпд Агаегіса,“ 
ОТСв “Тосіау," несколько 
радиопрограмм — большин- 
ство которых происходило 
из Нью-Йорка. 

Большинство публикаций 
было, по мнению специалис- 
тов-вирусологов, сфокусиро- 
вано вокруг Определенных 
антивирусных пакетов, а не 
вокруг того, как правильно 
защищаться от вирусов вооб- 
ще. Это, конечно, вызвало 
многочисленный рост про- 
даж антивирусных про- 
грамм — в некоторых ме- 
стах весь многомесячный их 
запас был распродан за не- 
сколько дней — но не при- 
бавило безопасности их но- 
вым владельцам. 

Фирма Іпіеі выпустила в 
свет некоторое неопределен- 
ное количество вирусов Ми- 
келанджело в составе своего 
сетевого сервера принтера 
ІАШрооІ 3.01, поставки ко- 
торого начались в январе 
этого года. 

Ыеѵ> чЬуІеа Аежг ИеЬѵогк, 
МагсН 6, 1992 
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ИНТЕГРАТОР “ВИКТОРИЯ" 

ЭТО: 

МОЩНЫЙ КОНСТРУКТОР МЕНЮ 
УДОБНЫЙ ФАЙЛОВЫЙ ПРОЦЕССОР 
ВСТРОЕННАЯ СИСТЕМА АВТОРИЗАЦИИ 

Вы хотите сделать свою работу легче и комфортабельнее? Да? 

Тогда ‘Виктория 1.8“ — это для Вас. 



Русскоязычный интерфейс интуитивен и не вызывает проблем в освоении 
ни у опытных пользователей, ни у новичков. 

Развитая система меню поможет забыть о существовании 

файловой системы 005, взяв на себя все функции по управлению работой 

на Вашем компьютере. 

Макрокоманды, созданные Вами и вызываемые нажатием горячих клавиш, 
повысят производительность труда. 

Работа с меню избавит Вас от случайных ошибок при работе с данными. 

Обширный набор сервисных функций возьмет на себя ваши заботы 
по обслуживанию компьютера. 

Аккуратная разработка сохранит оперативную память для выполнения 
Ваших задач — объем резидентной части составляет всего 2.9 Кбайта. 

Конечно, полная поддержка работы с мышью. 

Новые утилиты. 

И все эти гениальные способности умещаются в 300 Кбайтах дискового 
пространства. 

КАЖДЫЙ ПОКУПАТЕЛЬ “ВИКТОРИИ" ПОЛУЧАЕТ ПОЛНУЮ ПОДДЕРЖКУ, 
В ТОМ ЧИСЛЕ ПОСТАВКУ НОВЫХ ВЕРСИЙ СО СКИДКОЙ. 

КУПИВ “ВИКТОРИЮ", ВЫ ПРИОБРЕТЕТЕ НАДЕЖНУЮ 
И СИМПАТИЧНУЮ ПОМОЩНИЦУ. 

“ВИКТОРИЯ" СЭКОНОМИТ ВАШЕ ВРЕМЯ И ДЕНЬГИ. 

Телефоны для справок: (084-39)2-24-82, ( 095)471-32-63 , 

Письма направляйте по адресам: 

113093 Москва, а/я 37 

249020 Обнинск, Калужская обл., пл.Возрождения, 1-409 


НПФ ИнФоС 
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О языке ЗтаШаІк сегодня много 
говорят и пишут за рубежом. 

В нашей же стране о нем практически 
ничего не известно. Предлагаемая 
вашему вниманию статья содержит 
обзор сегодняшнего состояния языка 
ЗтаШаІк и перспектив его развития. 
Надеемся, она поможет нашим 
читателям определить свое отношение 
к этому языку или даже подтолкнет 
кого-то к его изучению. 


Язык ЗтаШаІк: концепция 
объектно-ориентированного 
программирования 


Наша информационная среда (ЬРЕ) 
приобрела свою мощность, дружественный 
интерфейс и расширяемость благодаря 
использованию ЗтаШаІк — самой передо- 
вой системы для разработки пользователь- 
ских интерфейсов на сегодняшний день. 

Тркгр Реенсканг, 
Центр Индустриализации, Осло 

Если в вашем мышлении произошел сдвиг 
от процедурного к объектно-ориентирован- 
ному программированию, вы выберете 
ЗтаШаІк как идеальную среду для разра- 
ботки прикладных программ. 

Билл Сайдэм, 
обозреватель Сотриіег Ьап^иа^е 


1. Введение 

За последние два года подобные отзывы стали ча- 
стым явлением в западной прессе, свидетельствующим 
о признании ЗтаШаІк мировой компьютерной обще- 
ственностью как не просто конкурентоспособного 
языка для разработки сложных программ, но и потен- 
циального лидера среди систем программирования во- 
обще. 


8таШа1к/Ѵ — версия ЗтаШаІк, разработанная 
фирмой Діеііаік для машин линии 1ВМ РС, становит- 
ся мировым бестселлером 1991 года. Вариант этой 
системы для М3 АѴіпбоѵѵз занял первое место в кон- 
курсе 'ѴѴіпсІоѵѵз-ориентированных систем программиро- 
вания, проводимом журналом РС \Ѵеек. Другой вари- 
ант 5та1Иа1к/Ѵ — для 05/2 Ргезепіаііоп Мапа^ег 
(РМ) — по мнению президента фирмы МісгозоГі 
Билла Гейтса, “позволит сделать РМ преемником 
008“. Наконец, поразительный по мощности и уни- 
кальным возможностям ЗтаШаІк/ОЬІесНѵогкз (версия 
фирмы РагсРІасе Зузіетз для всех популярных мощ- 
ных компьютеров и операционных систем) завершает 
прорыв ЗтаШаІк в мир коммерческих программных 
систем. 

Дату появления языка на свет обычно связывают с 
публикацией в августовском номере журнала Вуіе за 
1981 год серии статей, посвященных только что разра- 
ботанной в научно-исследовательском центре РАКС 
(Раіо АНо КезеагсН Сепіег) фирмы Хегох версии 
5таШа1к-80. 5таШа1к-80, который до сих пор счита- 
ется неофициальным стандартом языка, явился ре- 
зультатом проводимой с начала 70-х годов в РАКС 
(ныне РагсРІасе Зузіетз) работы по созданию системы 


КомпьютерПресс 4 "92 





22 


ЯЗЫК ЗМАІЛЛ'АІЖ: КОНЦЕПЦИЯ ОБЪЕКТНО-ОРИЕНТИРОВАННОГО ПРОГРАММИРОВАНИЯ 



Рис. 1. Языки программирования. История 


программирования, поддерживающей абсолютно но- 
вую по тому времени и многообещающую концепцию 
объектно-ориентированного программирования (ООП). 
Новая система, помимо ООП, предлагала целый букет 
новых технологических идей: графический интерфейс 
с перекрывающимися окнами, иерархические меню, 
использование мыши и пр. Эти идеи были активно 
приняты и легли в основу современных интерфейсов 
МасіпіозН, МісгозоН ЛѴішІодѵз, Ргезепіаііоп Мапа^ег и 
ІІпіх Х-\Ѵіпс1оіѵ5 Зузіет. ЗтаІПаІк является 
“дедушкой 1 * С++, О^есі Разсаі и других современных 
языков, поддерживающих наследование, инкапсуляцию 
и полиморфизм, и в отличие от своих “внуков** цели- 
ком построен на принципах ООП (см. рис.1). 

Закономерен вопрос: почему же тогда за прошед- 
шие десять лет ЗтаІИаІк даже отчасти не претендовал 
на ту популярность, которую приобрел, скажем, С++? 

Во-первых, и это главная причина, ЗтаІНаІк нуж- 
дается в мощной аппаратной поддержке. Первая вер- 
сия 8таШа1к-80 работала на рабочей станции фирмы 
Хегох, сделанной на процессоре М68010 и стоившей 
100 000 долл, (к слову, МасіпІозЬ фирмы Арріе по- 
строен по принципу этой машины). Естественно, мало 
кто мог позволить себе такую роскошь. Перспективы 
расширились с появлением и распространением отно- 
сительно доступных по цене рабочих станций фирм 
Зип, Арріе, Не\ѵ1еІІ Раскагё и БЕС, а также новых 
моделей 1ВМ РС и РЗ/2 с памятью свыше 2 Мбайт. 
Естественно, что технические трудности на Западе 


обернулись непреодолимым препятствием в СССР. 
Второй причиной является чисто психологическая 
трудность перехода на новый тип мышления в про- 
граммировании, требуемый ЗтаШаІк, в отличие, на- 
пример, от ОЬ]ес! Разсаі, в котором программист мо- 
жет просто не использовать средства ООП. 

Однако за прошедшие десять лет ситуация измени- 
лась. Рывок в микропроцессорной технологии обеспе- 
чил ЗтаШаІк достаточную аппаратную поддержку. 
Многотиражное распространение гибридных языков 
типа С++, успешно работающих как на супер-, так и 
на маломощных ПК, последующее появление объект- 
но-ориентированных баз данных, активная пропаганда 
ООП его апологетами, а также появление в 1986 году 
массовой учебной версии для линии 1ВМ РС (алфа- 
витно-цифровая система МеіЬосІз фирмы Оіеііаік, вы- 
росшая затем в ЗтаШаІк/Ѵ) привели ко всеобщему 
признанию ООП как передовой технологии програм- 
мирования, применение которой в условиях современ- 
ного кризиса ПО (когда цена оператора порой сравни- 
ма с ценой микропроцессора) многими рассматривает- 
ся как необходимость. 

Со второй половины 80-х годов начинают прово- 
диться конференции, отчасти или целиком посвящен- 
ные вопросам ООП. На конференции ООРЗІА’89 ве- 
дущие специалисты ІВМ Брюс Мартин и Нейт Эд- 
вардс проводят дискуссию, посвященную возможности 
научно-технической революции в ПО, обусловленной 
применением технологии ООП. Появляются новые 
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журналы с чисто объектно-ориенти- 
рованной тематикой, а с сентября 
1991 года выходит журнал ЗтаШаІк 
КерогІ, издающийся в Оттаве, Кана- 
да. В 1991 году конференции, посвя- 
щенные ООП, проходят одна за дру- 
гой: ЕСООР в Женеве; ТООП5 

ІІ5А'91 в Санта-Барбаре, США; ІРІР 
в Квебеке; ТООБ5'91 в Париже, 

“Конференция разработчиков 

5шаШа1к/Ѵ“ в Лос-Анджелесе; 

ЗСООР-Еигоре в Лондоне, ООР81А 
в Финиксе, США, и др. Причем 
8таШа1к — в центре внимания 
многих из них. Наконец, в сентябре 
в Братиславе, Чехо-Словакия, про- 
шла первая восточноевропейская 
конференция по ООП ЕазІЕигООРе, 
знаменующая вступление Восточной 
Европы в мир ООП. Открывала кон- 
ференцию Адель Голдберг, пре- 
зидент РагсРІасе Зузіешз и автор 
5шаШа1к-80, а над сценой зала, в 
котором проходила конференция, висел огромный раз- 
ноцветный воздушный шар — символ языка ЗшаШаІк. 

В ожидании надвигающегося бума, вероятно, 
уместно будет напомнить, что представляет из себя 
ЗтаІНаІк и какие принципы лежат в его основе. 

Объектно-ориентированное программиро- 
вание — это средство, парадигма для на- 
писания “хороших программ". 

Бьярн Страуструп, 
автор С++, Веіі БаЬ 

2. Концептуальная основа 
языка БтаІІіаІк 

Что такое “хорошая программа"? Это программа, 
которая, независимо от того, как и на чем она была 
написана, обладает следующими очевидными каче- 
ствами: 

1) допускает повторное использование своего кода для 
разработки других программ; 

2) расширяема, т.е. требует минимальных затрат на 
перепрограммирование при внесении дополнитель- 
ных свойств или модификации существующих; 

3) надежна; 

4) мобильна, т.е. подразумевает минимальные затраты 
при переносе на другие платформы; 

5) дешева: затраты на реализацию проектов бывают 
столь высоки, что порой от них приходится просто 
отказываться. 

Принципы ООП дают лучший из известных ответов 
на вопрос “как писать хорошие программы?". Этот 
ответ вытекает из бесчисленных дискуссий, статей, 
научных отчетов и материалов конференций, а также 
опыта разработки ПО за последнее десятилетие. Более 
или менее полная аргументация — скорее предмет 


книги, а не статьи; прекрасный при- 
мер такой книги — “Конструирова- 
ние объектно-ориентированного ПО“ 
Бертранда Мейера [5] (Б. Мейер — 
президент фирмы Іпіегасііѵе Зоійѵаге 
Епвіпеегіпб и автор объектно-ориен- 
тированного языка ЕіКеІ). Здесь бу- 
дет уместно привести принадлежа- 
щее Мейеру определение. 

“ Объектно-ориентированный ди- 
зайн — это построение программ- 
ных систем как структурированных 
наборов реализаций абстрактных 
типов данных “. 

За этим емким определением сто- 
ит ряд общепринятых понятий тео- 
рии ООП, главные из которых — 
инкапсуляция, наследование свойств 
и динамическое связывание. 

Попробуем дать пояснение к оп- 
ределению Мейера, попутно вводя 

эти основные понятия. 

Основная мысль заключается в 

построении (разработке) программы из классов 
объектов, которыми она манипулирует, а не из фун- 
кций, которые над ними (объектами) выполняются. 
Под классом подразумевается реализованный аб- 
страктный тип данных, а под объектом — конкрет- 
ные данные, т.е. экземпляр данного типа (класса). 

Например, 5 — экземпляр класса ЦелоеЧисло, а 

'привет' — экземпляр класса Строка. Что касается 
функций, то они определяются индивидуально над 
каждым типом данных. При этом сами данные 
(объекты)- становятся доступными только через эти 
функции, составляющие официальный интерфейс 
данного класса. Другими словами, реализация типа 
полностью скрыта от постороннего вмешательства 
(инкапсуляция) . 

Слово набор отражает принцип модульности, по ко- 
торому должны проектироваться классы как компо- 
ненты системы, независимые друг от друга. Так что, 
если вы в дальнейшем меняете что-то в одном компо- 
ненте, вы не должны будете модифицировать дру- 
гие — принцип, трудно осуществимый на практике, 
но ЗшаШаІк дает лучшие средства для его реализации. 

Инкапсуляция способствует соблюдению принципа 
модульности, но не является панацеей. Очень важное 
качество несет в себе полиморфизм, т.е. возможность 
не определять заранее в программах (функциях) 
используемые типы, а дать им возможность опреде- 
литься самим во время выполнения программы и, как 
следствие, дать возможность определиться функциям, 
выполняемым над этими типами (динамическое 
связывание ) . 

Наконец, слово структурированность отражает 
наличие важных связей между классами, а такое каче- 
ство, как наследование, дает возможность избежать 
дублирования программ или описаний в одном классе 
в том случае, если они уже реализованы в другом. 
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ЯЗЫК ЗМАІХТАЬК: КОНЦЕПЦИЯ ОБЪЕКТНО-ОРИЕНТИРОВАННОГО ПРОГРАММИРОВАНИЯ 


Еще раз подчеркнем, что процесс программирова- 
ния в рамках концепции ООП мыслится как 
“конструирование" ПО из уже существующих и вновь 
созданных (на основе существующих) компонент. А 
эти компоненты представляют собой реализации аб- 
страктных типов данных (или, по-другому, классы). 

И еще: сразу отметим, что ООП — программирова- 
ние в терминах объект и класс — адекватно способу 
естественного человеческого мышления, ибо человек 
мыслит образами и абстракциями. 

Уже из приведенного определения в достаточной 
степени явствует, что разработанная таким образом 
программа будет и доступной к повторному использо- 
ванию, и расширяемой (поскольку состоит из незави- 
симых компонент), и надежной (поскольку старые 
компоненты уже отлажены, а новые допускают неза- 
висимое тестирование), и относительно дешевой 
(поскольку не надо всегда программировать с самого 
начала, и сам процесс программирования идет легче), 
и мобильной (поскольку зависимые от платформы ча- 
сти скорее всего будут “упрятаны** в небольшое коли- 
чество низкоуровневых компонент). 

Объектно-ориентированная система программиро- 
вания (ООСП) — это система, поддерживающая объ- 
ектно-ориентированный стиль. 5>та11іа1к является 
именно такой системой. Он полностью отвечает кон- 
цепции ООП. Кто-то может оспаривать это утвержде- 
ние, указывая на наличие в ЗшаІКаІк иерархического 
наследования вместо множественного. Оставим за 
пределами нашей статьи дискуссию относительно не- 
обходимости такого наследования в ЗгпаШаІк, как и 
дискуссию о необходимости отсутствия контроля типов 
в ООП. Несомненно то, что ЗтаШаік — наиболее 
концептуально целостная и самая изящная из всех су- 
ществующих на сегодняшний день ООСП. 

Ниже кратко перечислены еще несколько важных 
принципов, спорных в отношении своей обязательной 
принадлежности к ООП, но с блеском реализованных 
в ЗілаІИаІк: 

- система должна быть построена с минимальным на- 
бором неизменяемых частей; 

- язык должен удовлетворять единой мощной концеп- 
ции, которая единообразно используется в любых 
областях его применения; 



- для поддержки духа созидания система должна быть 
целиком и полностью доступной пониманию отдель- 
ного индивидуума; 

- для того чтобы быть по-настоящему объектно-ориен- 
тированной, система должна обеспечивать автомати- 
ческое управление памятью. 

В идеале средства программирования 
(библиотеки, отладчики, средства измере- 
ния производительности, изобразительные 
средства и т.п.) должны интегрироваться в 
унифицированную среду программирова- 
ния. Лучшим примером такой среды явля- 
ется ЗшаІКаІк. 

Бьярн Страуструп 

3. Введение в БтаІІіаІк 

Формально любую среду программирования можно 
разделить на три составляющие: язык, средства про- 
граммирования (в обычном понимании — библи- 
отеки) и интерфейс (визуализация ввода-вывода, 
отладчики, инспекторы, редакторы, средства работы с 
файловыми системами и т.п.). 

Все три составляющие в ЗтаІИаІк объединены в 
общую среду — набор классов, доступный для расши- 
рения и модификации. Описание третьего компо- 
нента — интерфейса — не входит в задачу данной 
статьи. Отметим лишь, что, обладая редактором, спо- 
собным обеспечить работу с исходными текстами на 
самом современном уровне, и оконной графикой, не 
уступающей )Ѵіпсіо\ѵз, вместе с дополнительными ин- 
струментами интерфейс ЗтаШаік вполне может пре- 
тендовать на лидерство среди существующих интер- 
фейсов мощных ПК. 

3.1. Язык 

Как следует из названия, язык ЗтаШаік — 
“маленький** язык. И это действительно так. Поэтому, 
хотя в настоящем разделе описан и не весь Зшаіііаік, 
полное описание языка лишь ненамного превышает 
содержание данного раздела. 

Основные понятия 

Объект — структура данных с конкретной инфор- 
мацией, например, конкретное число. Простые объ- 
екты — базовые единицы системы — это числа, байты 
и символы. Сложные объекты состоят из простых и 
других сложных. Каждый объект принадлежит какому- 
либо классу. 

Класс — описатель структуры и функционирова- 
ния объекта (или абстрактный тип данных, описыва- 
ющий состав и поведение каждого объекта данного 
типа). Чтобы создать конкретный объект, классу 
(который тоже является объектом) надо послать со- 
общение новыйЭкзе маляр. 

Экземпляр класса — синоним объекта. 
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Метод — программа, реализующая некоторую 
функцию, определенную над объектами данного 
класса. 

Сообщение — вызов метода. 

Имя сообщения — имя конкретного сообщения, 
например, 

открытьФайл :для : вКаталоге: 

Весь синтаксис ЗтаШаІк сводится к посылке объ- 
екту сообщения, например, 5 факториал (сообщение 
факториал посылается объекту 5). Поскольку объ- 
ект 5 — целое число, в классе ЦелоеЧисло ищется и 
выполняется метод с именем факториал. В ЗтаШаІк 
существуют сотни классов и тысячи методов. Все они 
имеют имена (часто довольно длинные), отражающие 
их семантику. Например, 

'привет' вывестиНаПринтер 

выводит строку 'привет' на принтер. Это значительно 
улучшает читаемость программ. В данной статье все 
примеры в целях лучшей читаемости и экономии ме- 
ста приведены на русскоязычном ЗтаШаІк. 

Унарное сообщение — сообщение без аргумен- 
тов, имя которого состоит из одного слова, например, 
5 факториал. 

Бинарное сообщение — сообщение с одним ар- 
гументом, имя которого состоит из одного или не- 
скольких специальных символов, например, 5+10 
(сообщение + с аргументом 10). 

Составное сообщение — сообщение с одним или 
несколькими аргументами, имя которого состоит из 
нескольких слов, оканчивающихся двоеточием, напри- 
мер, 

ДискВ открытьФайл: Ішр' для: #запись вКаталоге: '\и$ег 

Выражение — синтаксическая единица — после- 
довательность сообщений, заканчивающаяся точкой, 
например, 6 * (8 - 5) факториал. Порядок вычисле- 
ния: сначала вычисляются выражения в круглых скоб- 
ках, затем последовательно — унарные, бинарные и 
составные сообщения. Вычисление сообщений оди- 
накового приоритета ведется слева направо. Результа- 
том вычисления в приведенном примере будет целое 
число 36. Любой метод всегда возвращает объект. Ре- 
зультатом вычисления выражения всегда является объ- 
ект, возвращенный последним выполненным методом. 

Имена переменных — имена, используемые для 
ссылок на объекты. Ймена могут быть глобальными и 
локальными. Локальные имена существуют только на 
протяжении выполнения метода, в котором они опре- 
делены. Локальные имена начинаются со строчной 
буквы. Глобальные имена существуют постоянно и 
начинаются с прописной буквы. 

Имена переменных экземпляра — в методах, 
определенных в конкретном классе, используются для 
ссылок на элементы объектов этого класса. Имена пе- 
ременных экземпляра начинаются со строчной буквы. 
Это, если хотите, названия полей в структуре объекта. 
Например, в классе Прямоугольник определены две 


переменные экземпляра — верхнийЛевыйУ гол и 
нижнийПравыйУ гол. Это означает, что объект 

прямоугольник состоит из двух объектов. Фактически 
это должны быть экземпляры класса Точка. Точки в 
свою очередь состоят из двух целых чисел, х и у. 
Таким образом, физически, в памяти, каждый 
объект — это набор ссылок на другие объекты. Такой 
подход обусловливает значительную экономию памяти. 
В языке существуют также индексированные 
переменные экземпляра. Если объект состоит, скажем, 
из четырех, а в классе указана одна именованная 
переменная, то остальные три являются 
индексированными, и доступ к ним осуществляется 
путем посылки объекту сообщения вПозиции: индекс , а 
не указанием имени. Например, Массив — целиком 
индексируемый объект. 

Имена переменных класса — глобальные имена, 
отличающиеся тем, что они определены только в дан- 
ном классе и доступны только из методов данного 
класса. 

Суперкласс/подкласс. Классы связаны отноше- 
нием наследования. Подкласс наследует свойства сво- 
его суперкласса. Например, Строка наследует свой- 
ства Массива, поскольку строка — это массив симво- 
лов. Массив в свою очередь наследует от Набора, ибо 
он — разновидность набора; при этом Строка, как 
следствие, тоже наследует от Набора (иерархическое 
наследование). Класс не может иметь более одного 
непосредственного суперкласса (т.е. в языке нет мно- 
жественного наследования). Наследовать свойства — 
значит наследовать имена переменных класса и эк- 
земпляра и методы. Методы, которые наследовать не- 
желательно, могут быть переопределены. 

Процесс программирования на ЗтаШзІк заключа- 
ется в программировании классов, т.е. описании типов 
объектов. Запрограммировать класс — это: 

1) указать, чьим подклассом он является; 

2) указать имена переменных класса; 

3) указать имена переменных экземпляра, 

4) определить (запрограммировать) методы и таким 
образом специфицировать поведение объектов дан- 
ного класса. 

Присваивание — указание, на какой объект ссы- 
лается данная переменная (точнее, ее имя). Примеры: 

ЧислоПродаж : = 1550 
точкаА : = точкаБ + точкаВ 

Литералы. Существует несколько классов, объекты 
которых могут представляться в программах явно, без 
использования переменных. Это Числа (10; 16г5А; 8е), 
Строки ('привет'). Массивы (#(5 'привет' 16г5А) — 
массив из трех элементов), Символы ($А; $#) и 
Блоки. Программа — это тоже объект, ее удобно 
иногда задавать явно, например, для организации 
циклов. Она выделяется квадратными скобками и на- 
зывается блоком. Пример: 

[хчетчик | счетчик факториал - 1 ] . 

Здесь счетчик — временная переменная блока. 


3 Зак. 2661 
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Выполнение Втаіііаік-программы — 
это последовательное выполнение 
посылок сообщений объектам. Во время 
выполнения определяется, какой объект 
получил то или иное сообщение. В 
классе этого объекта ищется метод, 
соответствующий данному имени 
сообщения. Если метод найден, то он 
выполняется, если нет — ищется в 
суперклассе, и далее по иерархии до 
самого старшего класса Объект, опи- 
сывающего общие свойства всех объек- 
тов (например, свойство иметь размер). 

Если имя сообщения не найдено и там, фиксируется 
ошибка. Это самый распространенный и едва ли не 
единственный тип ошибок в ЗтаШаІк-программах. 

Сам ($е10 — элемент языка, используемый для 
обозначения в методе в качестве получателя сообще- 
ния самого объекта, посылающего сообщение. Часто 
для выполнения какого-либо метода объекту прихо- 
дится посылать сообщения самому себе. 

Супер ($ирег) — элемент языка, дающий неоче- 
видное, но иногда очень полезное средство использо- 
вать метод суперкласса вместо метода, переопреде- 
ленного в своем классе. Отличается от сам только тем, 
что метод ищется, начиная с ближайшего суперкласса. 

Мы рассмотрели практически все понятия языка. 
Перед тем как перейти к примеру программы, заме- 
тим, что перечисленные понятия — необходимый и 
достаточный минимум. Любой программист заметит 
отсутствие в языке конструкций организации циклов и 
условий. Дело в том, что модель объект-сообщение 
достаточна для организации подобных конструкций 
средствами языка. В системе есть классы Истина и 
Ложь, имеющие единственные экземпляры. В обоих 
классах определено сообщение еслиИстина: с блоком 
в качестве аргумента. Соответствующий метод в клас- 
се Истина просто выполняет этот блок, а в классе 
Ложь — вообще ничего не делает. Такое сообщение 
посылается объекту — результату вычисления выраже- 
ния (в частности — просто результату посылки како- 
го-либо сообщения). Пример 

(числоА < 100) еслиИстина: [Терминал звонок] 

заставляет терминал пищать, если числоА меньше 
100. Круглые скобки здесь необязательны. 

Примеры 

Пример 1 

Предположим, перед окончанием работы вы хотите 
отправить нескольким адресатам сообщение типа 

'До свидания! К). К.' 

Допустим, этих адресатов четыре — два удаленных 
терминала (ваш компьютер включен в сеть), окно сис- 
темной информации на вашем экране и дисковый 
файл почты. 


Пусть все эти адресаты — уже 
существующие в системе объекты 
разных классов. Если их нет, их надо 
создать. 

Первое, что вы делаете, — создаете 
новый объект — множество объектов- 
адресатов. Поскольку вы захотите, 
чтобы этот новый объект “жил долго", 
вы заведете для него глобальную пере- 
менную: 

Адресаты := Множество 

новыйЭкземпляр. 

Компилятор сам включит Адресаты в число гло- 
бальных переменных. Теперь вы заполняете вновь со- 
зданное множество нужными объектами: 

Адресаты добавитьЭлемент: 

УдаленныйТерминал 1 

(затем, аналогично, ФайлПочты и т.д.). Теперь сама 
программа, вариант 1: 

| сообщение | 

сообщение := 01.12.91 17:30 До свидания! Ю.К.'. 

Адресаты дляВсехЭлементовВыполнить: [ :элемент | 
элемент поместитьНабор: сообщение] . 

Временные переменные (здесь одна — сообщение) 
указываются в вертикальных черточках. Метод 
дляВсехЭлементовВыполнить: определен в классе 
Набор и наследуется Множеством. Он выполняет за- 
данный аргументом блок столько раз, сколько элемен- 
тов содержится в наборе, — последовательно, для 
каждого элемента этого набора. Сообщение 
поместитьНабор: определено во всех нужных нам 
классах. Методы разных классов выполняют, по сути, 
одну и ту же функцию, но делают это, разумеется, 
по-разному: одно дело вывести строку в окно, и совсем 
другое — отправить ее в коммуникационный порт. Ка- 
кие методы когда будут работать — определится дина- 
мически, во время выполнения программы, в зависи- 
мости от того, какому классу будет принадлежать об- 
рабатываемый в данный момент объект. 

Для того, чтобы пользоваться этой программой в 
дальнейшем и сделать ее применимой для разных 
строк передаваемого текста, ее можно определить в 
классе Строка. Вариант 2 (метод класса Строка)-. 

отправитьВсемАдресатам 

“Отправить всем элементам множества Адресаты 
строку-получатель в качестве сообщения“ 

Адресаты дляВсехЭлементовВыполнить: [ :элемент | 
элемент поместитьНабор: сам ]. 

В кавычках дан комментарий. Теперь вы сможете 
пользоваться этим методом для посылки разных строк, 
например, 

'Привет! отправитьВсемАдресатам. 

Эта программа иллюстрирует замечательное пре- 
имущество динамического связывания. Предположим, 
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Рис. 2. ЗтаІПаІк. Принцип реализации 


вы хотите выводить вашу строку еще и на принтер. 
Все, что надо сделать, это выполнить 

Адресаты добавитьЭлемент: Принтер. 

Нет необходимости что-либо менять в программах. 
Затраты на модификацию минимальны. 

Метод отправитьВсемАдресатам не отражает пре- 
имуществ наследования. Поэтому приведем еще один 
пример. 

Пример 2 

Предположим, у вас разработана система моделиро- 
вания транспортного движения в городе — классы 
типа Улица , Перекресток , Светофор и т.п. и, ко- 
нечно, Автомобиль. У класса Автомобиль, очевидно, 
есть подклассы: Легковой, Автоцистерна и т.п. 
Теперь вам понадобилось внести в работу системы 
снегоуборочную машину. Вы определяете класс 
СнегоуборочнаяМашина как подкласс класса 
Автомобиль и программируете только специфические 
для нее свойства — в остальном она будет работать 
так же, как и все остальные автомобили. Не надо 
заботиться и о выделении памяти: как объект вообще 
машина наследует от класса Объект соответствующие 
методы. Перепрограммирование других классов 
системы также не требуется. 

Программисты приобретают уверенность в 
том, что если в системе отсутствует то или 
иное средство, они легко смогут его 
создать. 

Брайан Фут, 
профессор Иллинойского 
университета, США 

3.2. Средства программирования 

Средствами программирования в ЗтаШаІк явля- 
ются все его классы (в том числе и те, которые реали- 
зуют интерфейс системы) — их несколько сотен. 

Классы образуют древовидную иерархию по прин- 
ципу подкласс-суперкласс. Старшим в иерархии явля- 
ется класс Объект, описывающий свойства, общие для 
всех объектов. Остальные — его подклассы — описы- 
вают поведение всех мыслимых потенциально полез- 
ных программисту типов данных — от самого низкого 
до самого высокого уровня (целые и комплексные 


числа, точки, рамки, окна, меню, сло- 
вари, файлы, каталоги, потоки и т.п.). 
Все компоненты интерфейса (отладчики, 
редакторы, файл-сервер и т.п.) — объ- 
екты соответствующих классов иерар- 
хии. Они также целиком и по частям 
могут быть использованы как составные 
части пользовательских программ. Под- 
держка настолько мощна, что даже не 
для всех задач есть необходимость созда- 
вать новые классы. При необходимости 
же их легко строить. 

4. Реализация 

4.1. Основной принцип 

Принцип реализации ЗтаШаІк проиллюстрирован 
на рис. 2. 

Всем объектам системы, в том числе классам и ме- 
тодам, поставлены в соответствие их номера. Эти но- 
мера — виртуальные адреса объектов, образующие ад- 
ресное пространство виртуальной памяти. Отображе- 
ние виртуальной памяти в физическую называется 
образом системы. 

Виртуальная машина (ВМ) — это программно ре- 
ализованный 8-битный процессор, интерпретирующий 
так называемые байт-коды. Байт-коды — это ин- 
струкции ВМ, а методы ЗтаІПаІк — это программы в 
байт-кодах. Другими словами, компилятор ЗтаШаІк 
транслирует программы в промежуточный код, кото- 
рый затем интерпретируется ВМ. Типичный пример 
инструкции ВМ — “послать объекту, находящемуся в 
п-й позиции контекста, сообщение, имя которого на- 
ходится в т-й позиции области литералов метода, с 
аргументом в к-й позиции контекста 11 . Таким образом, 
язык ЗтаШаІк относится к языку ВМ примерно так 
же, как ассемблер к машинным кодам. 

Примитивные методы — это методы ЗтаШаІк, на- 
писанные на других языках (обычно на ассемблере, 
например, “умножение"). Примитивные методы — 
это низкоуровневый интерфейс ЗтаШаІк с внешним 
миром: через них осуществляется работа с ресурсами 
вычислительной системы, связь с другими програм- 
мными средствами (например, базами данных). Поль- 
зователь может включить свои программы, написан- 
ные на других языках, в виртуальную машину в каче- 
стве примитивных методов. 

Такой подход к реализации естественным образом 
вытекает из принципа построения системы. Отсюда 
же — и ее технические характеристики. 

4.2. Технические характеристики 

Компактность 

Одной из характерных особенностей системы, сразу 
же бросившейся в глаза при появлении первой ее вер- 
сии, была удивительная компактность ее исходных 
текстов. Первая версия 5та1На1к-80 по своей функци- 
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5іла1Иа1к-80 


40000 строк 


Приведенное выше высказывание Абдула Наби в 
целом справедливо, однако его необходимо проком- 
ментировать. В больших прикладных системах часто 
образуются “узкие места" — слишком медленно рабо- 
тающие компоненты (они перепрограммируются, на- 
пример, на С или ассемблере). Их содержание в про- 
екте, как правило, незначительно — доли процента. 

Изумительно было видеть, как прикладная 
система для Ореп Ілюк (Зіш) переносится 
в оконную среду МасіпІозН за 5 мин. 

Джон Раймер, 
аналитик Раігісіа ЗсуЬоІаі ОГГісе 


Рис. 3. Исходные тексты ІЖІХ В5Ю 4.2 
и ЗтаШаІк-80 

ональной нагрузке была сравнима с ее современницей 
ОС Ш4ІХ. И та, и другая включали редакторы, компи- 
ляторы, отладчики, сетевое ПО и т.п.; в ІЖІХ было 
больше языков, но в ЗшаШаІк — больше графики. Ис- 
ходные тексты ІЖІХ (версия ВЗЭ 4.2) содержали 
435 000 строк, а ЗшаШаІк — только 40 000. 

Требования к объему оперативной памяти 

Виртуальная машина с образом системы находятся 
в оперативной памяти и, естественно, занимают там 
значительное место. Например, ЗтаШаІк/Ѵ для 
ІВМ РС АТ “съедает" 170 Кбайт. При этом каждый 
метод занимает всего десятки байтов, поэтому даже 
сложные прикладные задачи не приводят к значитель- 
ному увеличению образа. 


Мобильность прикладных программ 

Здесь ЗшаШаІк — безусловный лидер. Он намного 
мобильнее, чем, скажем, С. Помимо того, что в 
ЗшаШаІк машинно-зависимые части “упрятаны" в не- 
большое количество стандартных примитивных мето- 
дов, что обеспечивает более высокую переносимость 
на уровне исходных текстов, он предлагает нечто 
большее — переносимость на уровне двоичных фай- 
лов! Техническое решение очевидно — образ системы, 
заключающий в себе все объекты, на каждом компью- 
тере интерпретируется соответствующей виртуальной 
машиной. Последняя версия фирмы РагсРІасе — 
8таШа1к/ОЪ]есРѵогкз К.. 4 — полностью реализует эту 
идею. (ЗшаШаІк/О^есІдѵогкз К.4 более чем в 5 раз 
дороже предыдущей версии. “Тотальная" переноси- 
мость — основная причина этого беспрецедентного 
скачка в цене.) 

4.3. Требования к аппаратуре 


Хорошо написанная ЗтаШаІк-программа 
обычно работает так же быстро, как ее эк- 
вивалент на С, а за время, которое вы сэ- 
кономите (на программировании), вы смо- 
жете написать еще две или три. 

Абдул Набм, 
директор офиса 
Кпоѵіесі&е $уКеті, США 

Скорость выполнения прикладных программ 

Скорость компиляции в ЗшаШаІк необыкновенно 
высока. Маленькая ЗтаШаік-программа транслируется 
в байт-код — и изменившая свое поведение система 
готова к выполнению. Стадия редактирования связей 
отсутствует. Этого, к сожалению, нельзя сказать о 
скорости самих прикладных программ, которые ин- 
терпретируются ВМ. 

Разработчики ЗшаШаІк оспаривают интерпретаци- 
онный характер системы. Они называют ЗшаШаІк 
системой динамической компиляции. Главный аргу- 
мент — наличие в последней версии 
ЗтаШаІк/ОІ^есІ'ѵогкз кэш-памяти, хранящей актив- 
ные программы в машинном коде. Действительно, в 
современном мире динамических библиотек и ско- 
ростных загрузчиков различие между компилятором и 
интерпретатором становится все менее важным, а ско- 
ростные качества ЗшаШаІк за последнее время за- 
метно улучшены. 


Жадная до памяти и небыстрая система может, тем 
не менее, в усеченном виде, успешно работать на 
ІВМ РС АТ и даже ХТ (как например, 5таШа1к/Ѵ). 
Однако для коммерческих приложений необходим ми- 
нимальный объем памяти 4 Мбайта и более мощная 
аппаратура (см. раздел 6 “Версии"). Требования к 
аппаратуре и функциональные качества системы 
определяют сферу ее применения. 

5. Области применения 

Выделим три основные сферы применения. 

1. Обучение. Пользователи: университеты, кол- 

леджи, школы. Цель использования: образование. 

2. Индивидуальное. Пользователи: фирмы разнооб- 
разного профиля. Цель использования: решение внут- 
ренних задач. 

3. Коммерческое. Пользователи: фирмы — разра- 
ботчики ПО. Цель использования: разработка ПО для 
конечного пользователя. 

5.1. Обучение 

ЗшаШаІк — чисто объектно-ориентированный язык. 
Он поддерживает объектно-ориентированный стиль 
программирования и оказывает сопротивление проце- 
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дурному. Недостатки программ, написанных на 
ЗтаШаІк в процедурном стиле, видны особенно отчет- 
ливо — они “некрасивы", труднее отлаживаются и 
модифицируются. Поэтому ЗтаШаІк — идеальная си- 
стема для обучения объектно-ориентированному про- 
граммированию. 

Любопытно, что авторы ЗтаШаІк начинали свою 
работу, ставя перед собой задачу создать такую си- 
стему программирования, которую легко могли бы 
освоить дети. Сейчас это серьезная мощная система 
(отнюдь не для детей), однако простота и универсаль- 
ность лежащих в ее основе концепций, единообразие 
и легкость доступа практически ко всем компонентам 
вычислительной системы для многих могут стать 
открытым окном в сложный и многообразный мир вы- 
числительной техники. Поэтому ЗтаІПаІк — прекрас- 
ная система для обучения программированию вообще. 

Относительная дешевизна версии ЗтаШа1к/Ѵ 
фирмы Бі^ііаік для ІВМ РС АТ (99 долл.) и политика 
РагсРІасе Зузіетз, дающей 90%-ную скидку универ- 
ситетам, делают ЗтаШаІк широко доступным для 
использования в сфере обучения. 

5.2. Индивидуальное использование 

Применение ЗтаШаІк в этой области продемон- 
стрируем на конкретном примере. 

Однажды авторам пришлось выполнять заказ 
СП “Элби“ на обработку большого количества файлов 
с текстами словарей. Эти файлы, частично введенные 
вручную, частично считанные сканером, изобиловали 
ошибками, перемежающимися буквами латинского и 
русского алфавитов в словах, несогласованными фор- 
матами, нарушенными ссылками, дублями и т.п. 

Работу нужно было выполнить на “дохлой 11 
ІВМ РС АТ (640 Кбайт). Авторы, некогда входившие в 
группу разработчиков ОС ИНМОС (русифицирован- 
ной версии ІІМІХ) и, следовательно, хорошо знающие 
язык С, оценили эту работу в 15 человеко-дней 
программирования на С и, затем, около трех часов 
самой обработки. Работа была сделана в ТМООП 
(русской учебной версии ЗтаШаІк для РС АТ) за 
3 дня. Сама обработка на машине велась 8 часов 
(см. рис. 4). 


Программирование на С Ц 


Рабата программы 


Программирование 
на ЗтаШаІк 


Работа программы 


Рис. 4. Время решения частной задачи по обработке 
текстовых файлов. Выбор средства 


В дальнейшем пришлось выполнять еще один подо- 
бный заказ, но с измененными требованиями, в част- 
ности, был изменен принцип сортировки. Перепро- 
граммирование заняло менее двух часов. 


5.3. Коммерческое использование 

На рис. 5 (весьма, конечно, условно) изображена 
зависимость стоимости разработки программ от класса 
решаемой задачи. Процедурные языки представлены 
языком С, объектно-ориентированные — ЗтаШаІк. 
Заметим сразу, что гибридные языки вели бы себя как 
нечто среднее; при этом характеристики С++ почти 
везде были бы лучше, чем у С, кроме простых задач 
(так как С++ дороже С). Прерывистая линия обозна- 
чает некоммерческое использование ЗтаШаІк на 
“слабых 11 ПК. Для разработки конкурентоспособных 
программ на ЗтаШаІк нужна более мощная аппара- 
тура. Скачки на графиках обозначают необходимость 
смены аппаратуры на более мощную. 



Драйверы Электронные Редакторы Сложные инфор- 
устройств таблицы мационные, экс- 

пертные системы, 
моделирование 

Рис. 5. Зависимость стоимости разработки ПО 
от сложности решаемой задачи 

На рисунке не отражены затраты на сопровождение 
в силу того, что не всякое ПО подразумевает сопро- 
вождение. О безусловных преимуществах ЗтаШаІк в 
этом плане говорилось выше (расширяемость). 

Сложность разработки растет стремительнее слож- 
ности задачи. Здесь у Зтаіііаік — лучшая характерис- 
тика. Итак, вступая в область сложных задач, мы по- 
падаем в царство ООП, и чем дальше в сторону слож- 
ности, тем весомее претензия ЗтаШаІк на “корону". 

Итак, сфера коммерческого применения 
Зтаіііаік — это: интеллектуальные информационные 
и экспертные системы, системы принятия решений и 
моделирования, обработка и формирование изображе- 
ний, сложные программы в планировании и управле- 
нии производством, банками, в городском хозяйстве, 
сельском хозяйстве, географии, геологии, биологии, 
медицине и т.д. 
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ЯЗЫК ЗМАІХТАЬК: КОНЦЕПЦИЯ ОБЪЕКТНО-ОРИЕНТИРОВАННОГО ПРОГРАММИРОВАНИЯ 


Таблица 1 


Версия 

Платформа 

Память 

Диск 

Операционная система 

Оконная система 


МасіпТозЬ II или 8Е/30 
С Р.Р.О 

4 Мб 

10 Мб 

Зузтет 6.0.4, 
МиІТіГіпсІег 6.0.4 
и 6.0.5 



Ароііо 0Ы3500, 4500 и 
НР 9000 Зегіез 400 

8 Мб 

10 Мб 

Оотаіп/ОЗ 10.2 

X ШпОои ЗузТет 

$таІ ІТаІк/ 
00 десіѵюгкз 
В. 4 

ОЕСзТаСіоп 

8 Мб 

10 Мб 

ІЛлІЗ 2 . 20 или 4 . 1 

X ШпОом ЗузТет 

НР 9000, Зег .300 и 400 

8 Мб 


ОХ 7.0 или 4.1 

X ШпОом ЗузТет 


ІВМ ВІ5С ЗузТет/6000 

8 Мб 


АІХ ѵегзіоп 3 

X ѴУіпОом Зузиет 


ЗипЗ, 5ип4 

8 Мб 

10 Мб 

ЗипОЗ 4 . 0 или 4 . 1 

X МіпОом ЗузТет 


ІВМ Р8/2 и совместимые 
на 80386 и 80486 

8 Мб 

10 Мб 

мз-ооз 3.3 

М3 МіпОом/з 3.0 

Зтаі ІТаІк/Ѵ 
МіпОомз 

ІВМ РС АТ на 80286 
и выше 

2 Мб 

10 Мб 

МЗ-йОЗ 3.3 

М3 ИіпОомз 3.0 

Зтаі ІТаІк/Ѵ 
286 

ІВМ РС АТ на 80286 
и выше 

1 Мб 

10 Мб 

МЗ-ООЗ 2.0 и выше 


Зтаі ІТаІк/Ѵ 

ІВМ РС АТ и выше 

512 Кб 

1 Мб 

МЗ-005 2.0 и выше 

— ч 

Зтаі ІТаІк/Ѵ 
РМ 

ІВМ РС АТ на 80286 
и выше 

2 Мб 

2 Мб 

03/2 

РгезепТаТіоп 

Мападег 

Зглаі ІТаІк/Ѵ 
Мае 

МасіпТозО II, Мае 8Е 
Мае Ріиз 

1,5 Мб 

10 Мб 

ЗузТет 6.0.4 


ТМООП (рус- 
скоязычный 
Зтаі ІТаІк) 

ІВМ РС ХТ/АТ 

512 Кб 

720 Кб 

ИЛИ 

2 НГМД 

МЗ-ООЗ 2.0 и выше 



ЗтаІНаІк/ОЬіесПѵогкз - торговый знак фирмы РагсРІасе Зузіешз. 
8шаШа1к/Ѵ - торговый знак фирмы Цівііаік. 

ТМООП - продукт ИПИ РАН. 


6. Версии 

На западном рынке Бтаіііаік доминируют две фир- 
мы — Оі^ііаік, охватывающая малые модели ПК, и 
РагсРІасе Зузіетз, специализирующаяся на мощных 
рабочих станциях. Поэтому фирме, решившей исполь- 
зовать ЗтаШаІк, не придется долго разбираться в раз- 
нообразии версий. Для каждой платформы существуют 
один-два варианта. Для пользователей, не владеющих 
английским языком, в ИПИ РАН (бывший ИПИАН 
СССР) разрабатываются русскоязычные версии 
ЗтаШаІк для компьютеров линии ІВМ РС. В табли- 
це 1 перечислены существующие версии ЗтаІНаІк и 
приведены их основные характеристики. 

Продолжающаяся сильная поддержка со 
стороны ІВМ и других компании может 
вытолкнуть Зтаіііаік на вершину. 

Стюарт Вудрмнг, 
аналитик Роггеаіег КевсагсЬ, США 

7. Заключение 

Последние версии ЗтаІНаІк для всех популярных 
мощных ПК, разработанные за последние годы раз- 


личными фирмами, дополнительные средства поддер- 
жки, в частности связь со всеми известными СУБД, 
привели к всеобщему признанию ЗтаІНаІк как 
передовой системы программирования. Многие 
крупнейшие фирмы, в их числе МісгозоН и ІВМ, 
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заключили с РагсРІасе и Оі^ііаік соглашения о 
координации деятельности. Развернута сеть центров 
обучения технологии объектно-ориентированного прог- 
раммирования. ЗтаИЫк готовится занять ключевые 
позиции среди систем программирования будущего. 

А.Иванов, Ю.Кремер 
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2. ООР5ГА91, ЗІСРІ^ 19оІісе8, Ѵ.24, N 0 10, 1989, 

р. 327-335. 


3. Сошриіег Ьап^иабе, Аргіі, 1990. 

4. ІЕЕЕ ЗоГЬѵаге. Магсіі, 1988. 

5. В.Меуег, “ОЬіесІ-ОгіепІесІ $о!і\ѵаге Сопаігисііоп", Ргепіісе- 
Наіі, 1989. 

6. Іоитаі оГ ОЬіесІ-Огіетесі Рго^гагатіп^, 1и1у-Аи2и5І, 1991. 

7. ОАТАМАТІОЫ, .Іиіу, 1991. 

Литература по Зтаіііаік на русском языке: 

1. Фути К., Судзуки Н. Языки программирования и схемо- 
техника СБИС: Пер. с япон. — М.: Мир, 1988. 

2. Иванов А.Г., Карпова А. В., Семик В.П., Филинов Ю.Е. 
Объектно-ориентированная среда программирования. Си- 
стемы и средства информатики. — М.: Наука, 1990. 

3. Технологический модуль объектно-ориентированного про- 
граммирования (ТМООП). Описание языка. — М.: Изд. 
ИПИАН СССР, 1989. 


ФИРМА “НИТА“ 

3 ГОДА 
СПЕЦИАЛИЗАЦИИ 
В ОБЛАСТИ 
ЛОКАЛЬНЫХ СЕТЕЙ 

НА 

СОВЕТСКОМ РЫНКЕ 


Основной поставщик импортного сетевого оборудования за рубли 

У нас Вы можете приобрести коммуникационное оборудование для создания локальных и 

распределенных сетей. 

Широко представлена оргтехника для офиса, брокерской конторы, крупного предприятия. 
Выносные и встроенные Науез-совместимые модемы с МИР 5. 

Факсы, факсмодемные платы, телефонные аппараты, калькуляторы и многое другое. 

НАШИ ДОСТОИНСТВА — УМЕРЕННЫЕ ЦЕНЫ, 

НЕМЕДЛЕННАЯ ПОСТАВКА, 

УСТАНОВКА СЕТЕЙ “ПОД КЛЮЧ“ 

Фирма “Нита“ приглашает к сотрудничеству коммерсантов, 
а также готова содействовать открытию филиалов и представительств 
в различных регионах и республиках на взаимовыгодных условиях. 


По всем вопросам Вы можете обращаться в нашу фирму по телефонам: 

( 095 ) 157 - 77 - 58 , 157 - 78-41 
Факс: 

( 095 ) 157 - 72-84 

Дополнительную информацию Вы можете получить по телефону- 

автоинформатору: 

( 095 ) 399 - 32-38 
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Малое предприятие 
"ИНФОРМАТИКА" 

Учредитель — 
институт проблем информатики 
Российской Академии Наук 


ОБЪЕКТНО-ОРИЕНТИРОВАННЫЕ СИСТЕМЫ ПРОГРАММИРОВАНИЯ 

НА ЯЗЫКЕ СМОЛТОК 

Это новые возможности в программировании: 

- описание решаемой задачи на языке объектов прикладной 
области 

- быстрое и эффективное создание программ 

- современный графический интерфейс пользователя 

- мощный набор встроенных средств программирования 

Девиз Смолтока — 

В мире нет ничего, кроме объектов 

Окна, меню, графика, мышь — все эти атрибуты совре- 
менных систем программирования были придуманы ав- 
торами языка Смолток. 

Работая в среде Смолтока, вы забудете про марку ваше- 
го компьютера и операционной системы. 

* Русскоязычные версии языка Смолток для ІВМ РС/АТ/ХТ 
(продукты ИПИ АН СССР) — оплата в рублях 



♦ 8та1ІІа1к/Ѵ 

Различные версии системы для всех моделей ІВМ РС 
(продукты фирмы Оі§йа1к Іпс., США) — оплата в СКВ 

♦ ОЪіесПѵогкз/БтаІИаІк 

Мощная среда программирования для 32-разрядных рабочих 
станций на базе ІВМ РС/ АТ/386, 486 и Р8-2, МасіпіозЬ II 
или 8Е/30 с Р.Р.Ч., Арроіо ОЫ3500, 4500 и НР 9000 8егіез 300 
и 400, ОЕСзІаІіоп, ІВМ К.І8С 8узІет/6000, 8ітЗ, 8ип4 
(продукты фирмы РагсРІасе 8узІет Іпс., США) — оплата в СКВ 


ПО ВОПРОСАМ ПРИОБРЕТЕНИЯ СИСТЕМ СМОЛТОК И ОБУЧЕНИЯ 
ОБЪЕКТНО-ОРИЕНТИРОВАННОМУ ПРОГРАММИРОВАНИЮ ОБРАЩАТЬСЯ ПО АДРЕСУ: 

117900 Москва ГСП-1, ул. Вавилова, 30/6, ИПИАН, МП “ Информатика “ 
Телефоны: (095)362-46-54, (095)237-70-00 
Факс: (095)310-70-50 
Телекс: 4111853 ШРО 5Ѵ 
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КАТАЛОГ ПРОДУКТОВ ФИРМЫ ШѴЕІХ 


Каталог продуктов 
фирмы ЫоѵеІІ 


СЕТЕВЫЕ ОПЕРАЦИОННЫЕ 
СИСТЕМЫ 


Продукты фирмы Моѵеіі обеспечивают создание вы- 
сокопроизводительных вычислительных сетей для 
большого числа деловых приложений. Среди продук- 
тов Ыоѵеіі — операционные системы, сетевые средства 
(включая средства обслуживания файлов и принтеров, 
средства поддержки баз данных, коммуникационные 
средства, средства обмена сообщениями и средства 
администрирования в сети І'ІеІ'ѴѴаге), а также инстру- 
ментальные средства для разработки сетевых приклад- 
ных программ. 

Ниже помещен обзор сетевых операционных си- 
стем, а также других продуктов, предлагаемых фир- 
мой Ыоѵеіі. 

Сетевая операционная система устанавливается на 
сервере и обеспечивает связь, необходимую для созда- 
ния единой вычислительной системы и сетевой опера- 
ционной среды. Блокировка файлов и записей, защита 
информации, создание буферов печати и обеспечение 
связи между процессами — это лишь несколько при- 
меров тех функций, которыми сетевая операционная 
система обеспечивает вычислительную сеть и выпол- 
няющиеся в ней прикладные программы. Сетевая опе- 
рационная система решает также проблемы, связан- 
ные с повышением производительности, поддержкой 
аппаратных и программных средств различных по- 
ставщиков, защитой информации и повышением на- 
дежности работы сети. 

Операционные системы ЫеОѴаге разработаны таким 
образом, чтобы оптимизировать ключевые параметры 
функционирования сети, включающие производи- 
тельность, надежность, степень защиты информации и 
поддержку нескольких сетевых стандартов. 

Архитектура сетевой 
операционной системы 

Сетевая операционная система состоит из следу- 
ющих компонентов: 

- операционная система сервера; 

- прикладные программы клиент-сервера; 

- программы обеспечения связи рабочих станций. 


Эти компоненты, взаимодействуя, организуют сете- 
вую среду, которая обеспечивает пользователям доступ 
к сетевым средствам. Взаимосвязь этих компонентов 
показана на рис. 2.1. 

Сетевая операционная система (называемая также 
операционной системой сервера) — это сердце сети, 
обеспечивающее выполнение базовых функций, необ- 
ходимых для поддержки основных сетевых операций, 
и, в частности, таких, как поддержка файловой си- 
стемы, управление памятью и планирование задач. 

Прикладные программы клиент-сервера выполня- 
ются в среде операционной системы сервера, обеспе- 
чивая сеть дополнительными функциональными воз- 
можностями. Эти программы обеспечивают пользова- 
телей всем, начиная с основных функций сети, таких, 
как блокировка файлов и записей, и кончая такими 
функциями, как поддержка запросов языка 5<ЗБ к со- 
вместно используемому серверу баз данных. 

Связь между операционной системой рабочей стан- 
ции и сетевой операционной системой сервера осу- 
ществляется сетевым коммуникационным программ- 
ным обеспечением, использующим аппаратные средст- 
ва сети для обеспечения связи с другими узлами и се- 
рверами сети. Коммуникационное программное обес- 
печение поддерживает протоколы связи, позволяющие 
передавать по сети запросы и принимать ответы на 
них. Пользователи и прикладные программы осущест- 
вляют доступ к серверам с помощью программ обеспе- 
чения связи, выполняющихся на рабочих станциях. 

Программы обеспечения связи с сетью устанавли- 
ваются на рабочих станциях пользователей вместе с 
операционными системами рабочих станций, такими, 
как 005, 03/2, ІЖІХ, М(іпсЗо\ѵ5 или МасіпІозЬ. 

Используя стандартные обращения к функциям каж- 
дой из этих операционных систем, прикладные про- 
граммы могут предоставлять доступ к средствам сети 
через программы связи. Пользователи получают пря- 
мой доступ к средствам сети, применяя такие ко- 
манды, как ШСІІ4 или другие сетевые утилиты, под- 
держиваемые пакеты связи рабочей станции. 
Обращения прикладных программ и команды 
пользователей передаются с помощью сетевых 
протоколов. Получив команду или запрос, сервер 
приступает к их обслуживанию. Ответ возвращается 
на рабочую станцию по тем же сетевым каналам. 

Большинство современных сетевых операционных 
систем разработаны и выполнены с использованием 
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Аппаратные соединения сети 


Рис. 2.1. Архитектура сетевой операционной системы 


механизмов поддержки различных специфических 
сред рабочих станций. Ыоѵеіі не поставляет операци- 
онные системы рабочих станций. Позиция фирмы за- 
ключается в том, чтобы предоставить независимую се- 
тевую операционную систему, пригодную для любой 
рабочей станции. Это позволяет КеПѴаге одинаково 
поддерживать среды различных рабочих станций в ин- 
тегрированной сетевой среде. Средства ЫеПѴаге до- 
ступны в сетях, которые используют разнообразное 
аппаратное обеспечение и различные комбинации 
протоколов. 

Производительность 

Операционные системы ИеПѴаге оптимизированы 
для обеспечения функций сети. Разработка с учетом 
специфики сети позволяет серверам ИеПѴаге обеспе- 
чивать производительность более высокую, чем у сер- 
веров в распределенных системах. Операционные си- 
стемы общего назначения, которые используются сер- 
верами в распределенных системах, предназначены 
для решения большого круга задач, поэтому они обыч- 
но не оптимизируются для сетевых приложений. 

ЫеОѴаге является лидером в области производи- 
тельности благодаря нескольким новшествам, исполь- 
зованным при создании этой операционной системы: 

- многозадачное ядро. Ядро ЫеІ\Ѵаге не только много- 
задачное, но и многопоточное, что позволяет Ыеі- 
\Ѵаге обеспечить многопользовательское обслужива- 


ние на сервере и гарантировать высокую производи- 
тельность в условиях интенсивной нагрузки; 

- элеваторный поиск. В ЫеІЛѴаге включена отдельная 
процедура чтения диска, отвечающая за чтение дан- 
ных с жесткого диска сервера и помещение их в бу- 
феры кэш-памяти. Эта процедура осуществляет со- 
ртировку приходящих запросов на чтение в соответ- 
ствии с текущим положением считывающих головок. 
Данный метод, называемый элеваторным поиском, 
оптимизирует перемещение головок считывания-за- 
писи, что обеспечивает существенное увеличение 
пропускной способности диска в условиях интенсив- 
ной нагрузки; 

- кэширование диска. ЫеіАѴаге хранит файлы, к кото- 
рым часто происходит обращение, в кэш-памяти сер- 
вера, откуда они могут быть считаны быстрее, чем с 
жесткого диска сервера. Процедура чтения диска 
считывает информацию, объем которой превышает 
реальный запрос, и помещает данные в память, 
предвидя будущие запросы к ним. Этот процесс ми- 
нимизирует количество физических обращений к 
диску, увеличивая производительность; 

- фоновая запись. Запись на диск управляется в Ыеі- 
\Ѵаге отдельной процедурой. Разделение операций 
чтения и записи позволяет сделать запись на диск 
фоновой задачей, выполняющейся в промежутках 
между периодами высокой нагрузки в сети; 

- перекрывающиеся операции поиска. Если сервер 
МеПУаге оснащен несколькими каналами доступа к 
жестким дискам, использование перекрывающихся 
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операций поиска осуществляет одновременный дос- 
туп к одному из дисков каждого канала, а не к одно- 
му диску в каждый момент времени. Независимое 
управление дисководами в таком режиме исключает 
ситуацию, при которой один диск занят в тот мо- 
мент, когда сервер получает информацию с другого; 

- индексированные таблицы размещения файлов 
(ТигЬо РАТ). Файловая система ЫеЛѴаге использует 
таблицы размещения файлов (РАТ) для размещения 
данных на жестких дисках сети. Если на сервере 
хранятся файлы размером более 2 Мбайт, ИеіѴѴаге 
индексирует соответствующую таблицу РАТ, обеспе- 
чивая более быстрый поиск и, следовательно, уско- 
ряя операции чтения диска. 

Надежность 

Продукты Ые)\Ѵаге содержат разнообразные сред- 
ства, обеспечивающие надежность работы системы и 
целостность данных. Перечисленные ниже средства 
защищают все ресурсы, начиная с дисковой памяти и 
кончая наиболее важными для прикладных программ 
файлами, позволяя ЫеПѴаге поддерживать высокий 
уровень надежности: 

- проверка чтением после записи. Каждая операция 
записи на диск сопровождается чтением записанной 
информации, позволяющим убедится в правильности 
ее записи; 

- дублирование директорий. Ме)\Ѵаге поддерживает 
копию структуры корневой директории. Если струк- 
тура нарушена, наличие резервной копии гарантиру- 
ет пользователям доступ к информации сети; 

- дублирование таблиц размещения файлов. ЫеСѴѴаге 
поддерживает копию таблицы размещения файлов 
(РАТ), что предотвращает потерю информации всего 
диска при порче одной из копий РАТ; 

- Но) Ріх (обработка физических сбоев диска). Но) Ріх 
используется как средство обнаружения дефектов на 
дисках и соответствующей коррекции дисковой 
информации по ходу работы; 

- устойчивость к сбоям системы (8РТ). 5РТ предо- 
ставляет несколько средств обеспечения надежности, 
включая зеркальное отображение диска, дублирова- 
ние диска и систему отслеживания транзакций — 
ТгапзаОіоп Тгаскіпв 8у5)ет. 

Защита информации 

Средства защиты встроены в операционные системы 
Ые)\Ѵаге на самом низком уровне и не являются до- 
полнительными прикладными программами, выполня- 
ющимися в операционных системах рабочих станций. 
Поскольку Ие^аге использует специализированную 
файловую систему, пользователи не могут осущест- 
влять доступ к файлам сети средствами Б08, 05/2, 
Ш9ІХ или любой другой операционной системы, даже 
если они имеют физический доступ к серверу. 


КАТАЛОГ ПРОДУКТОВ ФИРМЫ МОѴЕІА 


Продукты ЫеіѴ/аге обеспечивают механизм защиты 
на каждом из следующих уровней: 

- учетная информация пользователей; 

- пароли; 

- директории; 

- файлы; 

- межсетевая защита. 

Концепции имени пользователя, паролей и свойств 
пользователя были представлены Ыоѵеіі на сетевом 
рынке в 1983 году. Свойства пользователя представля- 
ют собой список ресурсов, к которым имеют доступ 
учетные функции пользователя, а также перечень 
прав на пользование данным ресурсом. Супервизор се- 
ти может указать дату, время работы и местоположе- 
ние каждого пользователя в сети. Средства выявления 
несанкционированного доступа и блокировок сообща- 
ют супервизору обо всех попытках незаконного про- 
никновения в сеть. 

Пароли хранятся в зашифрованном формате на же- 
стком диске сети. Супервизор может обязать пользова- 
телей периодически изменять пароли. 

В операционных системах Ые)\Ѵаге пароли переда- 
ются по кабелю от рабочей станции к серверу в за- 
шифрованном виде, таким образом предотвращается 
их рассекречивание в результате несанкционирован- 
ного подключения к кабелю. В операционных сис- 
темах версий 3.x Ыоѵеіі расширила средства защиты 
Ые)\Ѵаге в таких областях, как права доступа к 
файлам, защищенная сетевая консоль и функции 
шифрования. 

Если сервер Ые1\Ѵаге функционирует в невыделен- 
ном режиме, пользователь, хотя и работает на сервере 
как на рабочей станции, должен, тем не менее, под- 
ключаться к сети. В результате любой доступ к 
информации — через прикладные программы или лю- 
бым другим способом — разрешается только системой 
защиты Ые)\Ѵаге. 

Когда речь идет о системе защиты, Ые)\Ѵаге не де- 
лает различий между операционными системами ра- 
бочих станций. Система защиты рабочих станций под 
008, 'ѴѴіпбо'ѵз, 05/2, Масіп)озН и ІЛЧІХ организована 
одинаково. Все средства защиты одинаково приме- 
нимы к рабочим станциям всех поддерживаемых опе- 
рационных систем. 

Поддержка стандартов 

Благодаря тому, что операционные системы Ыеі- 
>Ѵаге поддерживают различные промышленные стан- 
дарты, пользователям обеспечивается постепенный пе- 
реход к технологиям будущего, а также защита ныне- 
шних вычислительных систем от старения. Поддержка 
стандартов также позволяет различным вычислитель- 
ным системам взаимодействовать друг с другом, что 
повышает эффективность работы и ценность сети. 
Стандарты вычислительных сетей можно разделить на 
две категории: стандарты прикладных программ и 
стандарты протоколов связи. 
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Стандарты прикладных программ 

В прошлом большинство сетевых прикладных про- 
грамм были ориентированы на рабочие станции, вы- 
полняя на них всю обработку информации. Приклад- 
ные программы этого типа основывались на стандар- 
тах файловых систем, установленных фирмой ІВМ для 
сред 008, 05/2 и \Ѵіпбо\ѵз, фирмой Арріе для среды 
МасіпІозЬ и стандартом бе-іасіо среды ІІЫІХ, разрабо- 
танным фирмой 5ип Місгозузіешз для удаленных 
служб файлов. Для того, чтобы обеспечить эффектив- 
ное объединение в сети вычислительных систем этих 
сред, ЫеІѴѴаге поддерживает соответствующие стан- 
дарты прикладных программ в каждой среде. 

Для обеспечения эффективной поддержки распре- 
деленных прикладных программ в неоднородной среде 
ЫеІѴѴаге поддерживает большое количество операци- 
онных систем сервера и клиента (рабочей станции), 
включая 008, 08/2, ОС МасіпІозЬ и ІІЫІХ в качестве 
вычислительных сред клиентов и 005, ЕІЫІХ, ѴМ8, а 
также другие операционные системы в качестве вы- 
числительных сред серверов. 

Независимо от операционной системы, в среде ко- 
торой работает сервер или клиент (рабочая станция), 
для установления сетевой связи между сервером и 
клиентом прикладные программы клиент-сервера 
используют протоколы взаимодействия процессов 
(ІРС). ЫеІѴѴаге поддерживает различные механизмы 
ІРС, включая протоколы ЫеІѴѴаге Зециепсеб Раске( 
ЕхсНап^е (8РХ) фирмы Ыоѵеіі, ЫеІВІ05 и Абѵапсеб 
Рго8гаш-Ю-Рго8гат Соттипісаііопз (АРРС) фирмы 
ІВМ, Ыатеб Рірез фирмы МісгозоН, ТгапзроП Ьеѵеі 
ІпІегГасе (ТЫ) фирмы АТ&Т и В5Э 5оскеІз. 

Стандарты протоколов связи 

Для создания сетевой вычислительной среды сете- 
вые операционные системы используют протоколы 
связи. Сетевые протоколы могут быть разделены на 
три группы: протоколы среды передачи, транспортные 
протоколы и протоколы клиент-сервера. Каждый тип 
протокола обеспечивает специфические функции, а 
все вместе — они позволяют пользователям осущест- 
влять совместный доступ к ресурсам. 

Протоколы среды передачи определяют тип физи- 
ческого соединения, используемого в сети. ЫеІѴѴаге 
поддерживает более 100 различных сетевых адаптеров. 
После того, как установлена связь между узлами сети 
на аппаратном уровне, требуется использование тран- 
спортного протокола, обеспечивающего сетевые 
службы следующего уровня. Транспортный протокол, 
как следует из названия, обеспечивает механизм про- 
движения пакетов данных от одного узла к другому. 
ЫеіѴ/аге поддерживает транспортные протоколы 
5РХ/ІРХ фирмы Ыоѵеіі, АррІеТаІк фирмы АрІІе, а 
также протоколы стандартов ТСР/ІР и 081. 

Когда установлены аппаратные соединения и ини- 
циализированы функции транспортного уровня, сле- 


дующим уровнем, необходимым для обеспечения поль- 
зователю доступа к средствам сети, является протокол 
клиент-сервера. Протокол клиент-сервера определяет 
режим, в котором рабочая станция выдает запросы на 
получение информации и доступа к средствам сервера. 
Этот же протокол определяет режим ответа сервера на 
запросы. 

Все эти протоколы работают взаимосвязано, предо- 
ставляя пользователям возможность делать запросы к 
сетевым данным и службам, находящимся на опреде- 
ленных узлах сети, скажем таких, как серверы. На- 
пример, запрос пользователя на открытие файла 
обычно делается прикладной программой. Запрос этой 
прикладной программы перехватывается сетевой про- 
граммой, выполняющейся на рабочей станции, и пере- 
водится в формат соответствующего протокола клиент- 
сервера. Затем транспортный механизм передает за- 
прос серверу, используя соединение, обеспеченное се- 
тевой средой передачи. 

Программа сервера, принимающая запрос, пони- 
мает его благодаря тому, что использует такой же 
протокол клиент-сервера. Она обрабатывает запрос, 
формирует ответ в формате протокола клиент-сервера 
и возвращает его рабочей станции с помощью тран- 
спортного протокола. 

Вместо того, чтобы требовать от всех сетей исполь- 
зования одних и тех же протоколов, продукты ЫеІ- 
ѴѴаге поддерживают различные стандарты протоколов. 
Сетевая операционная система интегрирует различные 
стандарты, обеспечивая переход к новым стандартам, 
таким как 081, по мере их появления. 

ОПЕРАЦИОННЫЕ СИСТЕМЫ 

ИЕТѴУАРЕ 


Первоначально Ыоѵеіі разрабатывала ЫеІѴѴаге в ка- 
честве операционной системы сервера для 
Моѵеіі 8-ЫеІ — сети, использовавшей звездообразную 
топологию и патентованный сервер с микропроцес- 
сором Моіогоіа МС68000. Когда фирма ІВМ выпустила 
РС ХТ, Ыоѵеіі осознала, что ЫеіѴ/аге может быть лег- 
ко перенесена в архитектуру процессоров семейства 
Іпіеі 8088, и что тогда она сможет поддерживать лю- 
бые имеющиеся на рынке сети. 

Первая версия ЫеІѴѴаге была выпущена Ыоѵеіі в на- 
чале 1983 года. В 1985 году Ыоѵеіі представила Абѵап- 
себ ЫеІѴѴаге ѵі.0, которая расширяла функциональные 
возможности операционной системы сервера. Абѵапсеб 
ЫеІѴѴаге версии 1.2, также выпущенная в 1985 году, 
стала первой операционной системой для процессора 
Іпіеі 80286, работающей в защищенном режиме. 

Абѵапсеб ЫеІѴѴаге версии 2.0 была выпущена в 
1986 году и добавила новые функциональные возмож- 
ности в области производительности и объединения 
сетей. Полностью используя возможность работы про- 
цессора в защищенном режиме, Абѵапсеб ЫеІѴѴаге 
обеспечила возможности, ранее не доступные для опе- 
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рационных систем реального режима, ограниченных 
640 Кбайтами. Версия 2.0 впервые обеспечила пользо- 
вателям возможность объединения до четырех различ- 
ных сетей на одном сервере. 

В 1987 года 19оѵе11 выпустила 5РТ ЫеіѴ/аге, сущест- 
венно повысив надежность системы и расширив возмо- 
жности управления в операционных системах ЫеГ 
\Ѵаге. Такие средства, как РССЖ50ГЕ, учет использу- 
емых ресурсов и усовершенствованная система защиты 
позволили супервизорам сети определять, как и когда 
пользователи осуществляют доступ к информации и 
ресурсам. Интерфейс прикладных программ — до- 
полнительных процессов (ѴАР) впервые обеспечил 
средства, позволившие прикладным программам вы- 
полняться на сервере вместе с МеіѴѴаге и использовать 
преимущества имеющихся в ней функций. 

Операционные системы ЫеОѴаге ѵ2.15 и МеПѴаге 
Гог МасіпІозЬ появились на рынке в 1988 году, добавив 
в КеІ\Ѵаге средства поддержки МасіпІозЬ. Использова- 
ние ЫеіѴ/аге Гог МасіпІозЬ вместе с серверами N61- 
Ѵ(аге ѵ2.15 обеспечивает пользователям МасіпІозЬ до- 
ступ к серверам Ые(\Ѵаге с настольных систем Масіп- 
ІозЬ, позволяя им осуществлять прозрачный поиск и 
хранение информации. Все средства ЫеОѴаге, включая 
устойчивость к сбоям и высокую степень защиты, ста- 
новятся доступными пользователям МасіпІозЬ. 

ЫеіАѴаге 386 ѵЗ.О, полностью 32-разрядная версия 
операционной системы для серверов с микропроцессо- 
рами 80386 и 80486, была выпущена в сентябре 
1989 года. ЫеПѴаге 386 обеспечивает существенные 
преимущества в области защиты, производительности 
и гибкости, а также поддержку протоколов. Она отве- 
чает самым передовым требованиям как среда распре- 
деленных программ. В июне 1990 года Ыоѵеіі выпусти- 
ла ИеОУаге 386 версии 3.1, в которой повышена про- 
изводительность и надежность сети, усовершенствова- 
ны средства управления сетью и инструментальные 
средства для разработчиков. 

В 1991 году Ноѵеіі объединила свои операционные 
системы для процессора 80286 (ЗРТ, Агіѵапсеб и ЕЬ5 
МеіѴ/аге) в продукте Ыеі\Ѵаге ѵ2.2, а также выпустила 
ЫеІѴѴаге ѵЗ .11. 

ЫеіѴ/аге ѵ2.2 — это полнофункциональная сетевая 
операционная система для среды рабочей группы, под- 
держивающая от 5 до 100 пользователей на одном 
сервере. Ме(\Ѵаге ѵЗ.11 — первая сетевая операцион- 
ная система, поддерживающая службы файлов и пе- 
чати на рабочих станциях 008, МасіпІозЬ, ХѴіпсіоѵѵз, 
05/2 и ШІХ. 

Операционные системы сервера 

Продукты семейства МеНѴаге могут быть классифи- 
цированы по предоставляемым ими средствам и фун- 
кциональным возможностям. 

ЫеОѴаге ѵ2.2 идеально подходит для мелких и сред- 
них предприятий, а также для рабочих групп внутри 
больших компаний. МеПѴаге ѵ2.2 используется ". не- 


больших сетях, требующих работы сервера в невыде- 
ленном режиме, а также в сетях среднего размера, ус- 
танавливаемых в отделах и использующих выделенные 
серверы. Высокая производительность, поддержка объ- 
единенных сетей (локальных и удаленных) и полный 
набор средств управления делают ЫеПѴаге ѵ2.2 иде- 
альной для использования даже в самых современных 
сетях. ЫеіѴ/аге ѵ2.2 включает средства, гарантирую- 
щие надежную работу системы, что позволяет исполь- 
зовать эту ОС для важных прикладных программ. 

ЫеПѴаге ѵЗ.11 обеспечивает переход от сетей рабо- 
чих групп и отделов к более крупным сетям. Разрабо- 
танная для общекорпоративных сетей, поддержива- 
ющих сотни пользователей на одном сервере, МеІ\Ѵаге 
ѵЗ.11 продемонстрировала новые возможности сетевой 
технологии. Ме(\Ѵаге ѵЗ.11 обеспечивает объединение 
в одну сеть миниЭВМ, сетевых серверов на основе 
ІВМ-совместимых персональных компьютеров, а также 
рабочих станций 005, \Ѵіпйоѵз, 05/2, ІІЫІХ и Мас- 
іпІозЬ. 

В таблице 2.1 представлена сравнительная характе- 
ристика функциональных возможностей К'еПѴаге ѵ2.2 
и ЫеіѴ^аге ѵЗ.1 1. 

Средства ИеІ^аге 

Чтобы усовершенствовать возможности операцион- 
ной системы сервера ЫеОѴаге, фирма Моѵеіі предо- 
ставляет сетевые средства в виде дополнительных про- 
цессов (ѴАР) и загружаемых модулей КеПѴаге (КЬМ), 
позволяющих прикладным программам, выполня- 
ющимся на рабочих станциях с различными операци- 
онными системами, осуществлять доступ к ресурсам 
сети. 

МеЛѴаге Гог МасіпІозЬ ѵЗ.О — это программное 
обеспечение сервера и клиента, обеспечивающее рабо- 
чим станциям МасіпІозЬ доступ к файловой системе, 
средствам печати и маршрутизации Ые(\Ѵаге. Поддер- 
жка МасіпІозЬ в ЫеОѴаге ѵЗ.11 реализована на основе 
загружаемых модулей ЫЬМ, позволяющих пользовате- 
лям МасіпІозЬ получать полное обслуживание, обеспе- 
чиваемое этой 32-разрядной операционной системой 
фирмы Ыоѵеіі. ЫеЛѴаге Гог МасіпІозЬ ѵ2.2 выполняется 
в качестве процесса ѴАР на сервере ЫеПѴаге ѵ2.2. 

ЫеіѴѴаге Кециезіег Гог 05/2 служит средством вза- 
имодействия рабочих станций под 05/2 с сетью Ыеі- 
>Ѵаге. КеіѴ/аге Ргіпі 5егѵег дает возможность пользо- 
вателям сети совместно использовать принтеры, 
отличные от подключенного к серверу данной сети. 
КеПѴаге Васкир ѴАР обеспечивает пользователям 
МеіѴ^аге ѵ2.2 возможность резервирования и восста- 
новления информации. 

Опции сетевой связи 

Ыоѵеіі предлагает заказчикам широкий выбор опций 
протокола ТСР/ІР для пользователей ПОЗ, >Ѵіпс1о\ѵз, 
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05/2 и МасіпІозН. Связь поддерживается семейством 
продуктов І.АЫ Ѵ/огкРІасе. Эти продукты обеспечи- 
вают одновременный доступ пользователей к серверам 
МеОѴаге и ресурсам других распределенных систем, 
использующих стандарты ТСР/ІР. Моѵеіі также по- 
ставляет МиШ19еІ, аппаратно-независимую реализа- 
цию сетей ТСР/ІР, предназначенную для удаленной 
связи со средами ѴАХ/ѴМ5. 

Сетевые адаптеры 
и драйверы аппаратных средств 

Моѵеіі всячески приветствует создание другими 
фирмами Ыоѵеіі-совместимых аппаратных продуктов. 
Моѵеіі активно сотрудничает с производителями дис- 
ководов, сетевых адаптеров, серверов сети и- другого 

Таблица 2.1 


оборудования, обеспечивая их помощью и средствами 
разработки, необходимыми для поддержки МеІ\Ѵаге. 
Например, спецификации интерфейса Ореп Оаіа-Ілпк 
Іпіегіасе фирмы Моѵеіі позволяют другим разработчи- 
кам создавать драйверы ЫеіѴѴаге для выпускаемых 
ими адаптеров. Интерфейс ЫеЛѴаге Оізк Огіѵег обес- 
печивает одинаковые функциональные возможности 
всем производителям дисководов. Когда драйверы для 
этих продуктов созданы, Моѵеіі предлагает услуги по 
апробации, позволяющие другим производителям про- 
давать продукты для среды Меі\Ѵаге, одобренные 
Моѵеіі. Это является как бы дополнительным 
сертификатом качества. 

Моѵеіі поставляет аппаратные драйверы для адапте- 
ров 15А, Місго СЬаппеІ и ЕІ5А ЕіНегпеІ. Адаптер 
МЕ3200 ЕіНегпеІ фирмы Моѵеіі был разработан специ- 
ально в качестве дополнения к 32-разрядной операци- 
онной системе 19еІ\Ѵаге и новому мощному поко- 
лению серверов ЕІ8А. 


Средства КеІКаге 

Поддержка 1)05 3.x 
Поддержка ПОЗ 4.0 
Поддержка 005 5.0 

КеІКаге 2.2 
Да 
Да 
Да 

КеІКаге 3.11 
Да 
Да 
Да 

Поддержка Кіпйоиз 3.0 

Да 

Да 

Поддержка 05/2 ѵі.3 

Да 

Да 

Поддержка МасіпФозЬ 

Да 

Да* 

Поддержка N75 ЩІХ 

Нет 

Да* 

Поддержка 051 РТАМ 

Нет 

Да* 

5РХ/ІРХ 

Да 

Да 

КеІВІОЗ 

Да 

Да 

П05 Калей Рірез 

Да 

Да 

05/2 Налей Рірез 

Да 

Да 

ТСР/ІР 

Нет 

Да 

АррІеТаІк 

Да 

Да* 

Динамическая 

конфигурация 

Нет 

Да 

Управление 
рабочими группами 

Нет 

Да 

Шифрование паролей 

Да 

Да 

Азупс. Негаоіе 
Коиіег (С0М1/С0М2) 

Да 

Да 

Учет используемых 
ресурсов 

Да 

Да 

Усовершенствованная 
система защиты 

Да 

Да 

5РТ Ьеѵеі I А II 

II 

II 

Текущий контроль за ЧР5 

Да 

Да 

КеІКаге Кале Зегѵісе 

Да» 

Да* 

НеІИагѳ йегаоіе 
Мапа^ешепІ РасіИІу 

Нет 

Да 

Поддерживаемые шиш 

НС А, І5А 

МСА, І5А.ЕІ5А 

Конфигурации 

пользователей 

5, 10, 50 

20, 100, 250 

Поддерживаемые топологии 

100+ 

'15 

Поддержка дополнительных 
драйверов ЛВС 

Да 

Да 

Объединенные сети 

Да 

Да 

Максимальный объем 
дисковой памяти (1) 

2 Гбайт 

32 Тбайт 

Максимальный 
размер файла (1) 

256 Мбайт 

4 Гбайт 

Максимальное число 
открытых файлов 

1,000 

100,000 

Примечания: 

(1) Все максимальные значения могут не поддерживаться одновре- 

менно. 

В зависимости от имеющихся 
* Может быть установлена в 

аппаратных средств. 

качестве дополнительного продукта. 


ПРОДУКТЫ ОБЕСПЕЧЕНИЯ 
СЕТЕВЫХ СЛУЖБ 


Службы Меі\Ѵаге представляют собой ядро се- 
тевой операционной системы. Они обеспечивают 
пользователей всем, начиная с основной службы 
сети, такой как средство блокировки файлов и за- 
писей, и кончая другими службами, такими как 
средства запросов языка 80Ь к совместно исполь- 
зуемому серверу баз данных. Службы Меі\Ѵаге 
можно разделить на пять категорий: службы фай- 
лов и печати, службы баз данных, службы связи, 
службы передачи сообщений и службы управле- 
ния сетью. 

—Моѵеіі впервые начала поддерживать сетевые 
службы на уровне прикладных программ клиент- 
сервера в МеІ'ѴѴаге ѵ2.1, создав для этого интер- 
фейс дополнительного процесса (ѴАР). Интер- 
фейс ѴАР позволяет ядру прикладной программы 
клиент-сервера выполняться на сервере МеІ\Ѵаге 
вместе с ОС 19е1\Ѵаге. В настоящее время интер- 
фейс ѴАР входит в операционную систему Ыеі- 
\Ѵаге версии 2.2 и поддерживает множество сете- 
вых служб. 

ЫеІ'ѴѴаге ѵЗ.11 включает новый набор интер- 
фейсов программирования и инструментальных 
средств для сетевых служб. В операционной си- 
стеме ЫеіѴ/аге ѵЗ.11 прикладные программы кли- 
ент-сервера выполняются в качестве загружаемых 
модулей МеІѴ'аге (ЬИА!). ЫеГѴѴаге ѵЗ.11 обеспечи- 
вает дополнительные мощности, необходимые для 
поддержки интенсивно используемых сетевых 
служб сервера. 

Прикладные программы N І^М в полной мере 
используют систему защиты МеІ\Ѵаге. Прикладная 
программа может создавать в среде 19еІ\Ѵаге свою 
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собственную защиту или обращаться напрямую к 
средствам защиты, определяемым менеджером сети 
для пользователя. Интерфейс N04 обеспечивает стан- 
дартную среду программирования, делая создание и 
тестирование N04 таким же простым, как создание и 
тестирование прикладной программы 005. Поскольку 
ЫеіѴѴаге ѵЗ.11 имеет модульную архитектуру, N04 
могут быть загружены и “подогнаны 1 * под операцион- 
ную систему без прерывания работы сервера. 

ПО служб файлов и печати 

Службы файлов и печати (базовые сетевые службы) 
оснащены дополнительными средствами обеспечения 
надежности, защиты информации и повышения про- 
изводительности. Три продукта Ыоѵеіі используют 
преимущества служб файлов и печати ЫеіѴѴаге: 
ЫеіѴѴаге Гог ѴМ5, ЫеіѴѴаге ЫРЗ, ЫеіѴѴаге РТАМ. 

ЫеіѴѴаге Гог ѴМ5 — это прикладная программа 
клиент-сервера, позволяющая системе ОЕС ѴАХ/ѴМЗ 
функционировать в качестве сервера файлов и печати 
ЫеіѴѴаге, обеспечивая пользователям 003, ѴѴіпгіолѵз и 
03/2 прозрачное использование информации, при- 
кладных программ и служб печати совместно с поль- 
зователями, работающими на терминалах ѴАХ. 

ЫеіѴѴаге ЫРЗ обеспечивает рабочим станциям ІІЫІХ 
прозрачный доступ к операционной системе ЫеіѴѴаге 
ѵЗ.11. ЫеіѴѴаге ЫРЗ состоит из нескольких ЫШ, кото- 
рые добавляют серверу ЫеіѴѴаге возможности сервера 
ЫеЬѵогк РПе Зузіет (ЫРЗ). Если установлена про- 
грамма ЫеіѴѴаге ЫРЗ, рабочие станции, использующие 
службы клиента ЫРЗ, могут работать с файлами со- 
вместно с другими клиентами ЫеіѴѴаге (такими как 
рабочие станции 005, МасіпЮзЬ и 05/2) и посылать 
задания на печать принтерам ЫеіѴѴаге. 

ЫеіѴѴаге РТАМ — это сервер 051 РТАМ, позволя- 
ющий различным клиентам РТАМ осуществлять до- 
ступ к файловой системе ЫеіѴѴаге ѵЗ.11. Этот продукт, 
реализованный на стандартном протоколе, дает ключ 
к решению проблемы взаимодействия вычислительных 
систем различных изготовителей с сетями ЫеіѴѴаге. 
ЫеіѴѴаге РТАМ реализует все семь уровней протоколов 
051 и обеспечивает обмен файлами между ЫеіѴѴаге и 
другими системами 081 независимо от того, какую 
аппаратную или программную среду они используют. 
Кроме того, этот продукт позволяет клиентам РТАМ 
направлять файлы в очереди печати ЫеіѴѴаге. 

ПО служб баз данных 

Обеспечение служб баз данных для прикладных 
программ клиент-сервера — важная составная часть 
подхода Ыоѵеіі к сетевым приложениям. Основные 
службы баз данных ЫеіѴѴаге предоставляют пользова- 
телям надежную основу для выполнения важных при- 
кладных программ, таких как электронные таблицы, 
бухгалтерские пакеты и системы проектирования. 


Службы баз данных ЫеіѴѴаге также избавляют раз- 
работчиков от написания программы управления запи- 
сями или ядра реляционной базы данных, необходимо- 
го для создания прикладных программ клиента. Ис- 
пользуя службы баз данных ЫеіѴѴаге, разработчики 
создают высокоэффективные системы управления дан- 
ными клиент-сервера. Ыоѵеіі обеспечивает поддержку 
прикладных программ клиент-сервера двумя своими 
продуктами: ЫеіѴѴаге Вігіеѵе и ЫеіѴѴаге 5()0 

ЫеіѴѴаге Вігіеѵе — это программа управления запи- 
сями с индексацией по ключу, которая выполняется на 
сервере и обеспечивает высокую производительность 
обработки данных. ЫеіѴѴаге Вігіеѵе является стандар- 
том бе-іасіо систем управления записями в ЛВС и 
применяется большим числом разработчиков приклад- 
ных программ. ЫеіѴѴаге 8(}Е — это высокопроизводи- 
тельное ядро баз данных, разработанное Ыоѵеіі специ- 
ально для среды ЫеіѴѴаге. ЫеіѴѴаге 5<2Ь добавляет к 
надежности ЫеіѴѴаге систему обеспечения защиты и 
целостности данных 5(}Ь. Поскольку ЫеіѴѴаге Вігіеѵе 
и ЫеіѴѴаге 8<ЗЬ совместимы друг с другом, прикладные 
программы, написанные для любого из этих продук- 
тов, могут совместно использовать данные. Ыоѵеіі по- 
ставляет также инструментальные наборы для Ыеі- 
ѴѴаге Вігіеѵе и ЫеіѴѴаге 5(}Ь. 

Продукты обеспечения связи 

Ыоѵеіі производит весь набор продуктов обеспече- 
ния связи, интегрированных с сетями ЫеіѴѴаге. 

Виды соединений 

В среде ЫеіѴѴаге потребности связи могут быть раз- 
делены на три основных группы: 

- соединение с системами ІВМ ЗЫА; 

- соединение персональных компьютеров с главными 
системами; 

- соединения в региональных вычислительных сетях. 

Соединение с удаленным или локальным вычисли- 
тельным ресурсом должно быть быстрым, простым и 
эффективным и в то же время поддерживающим вы- 
сокий уровень фукциональности. Чтобы обеспечить 
такой режим работы, коммуникационные продукты 
Ыоѵеіі тесно интегрированы с другими компонентами 
сети, в частности, с сетевой операционной системой. 
Это обеспечивает единый интерфейс пользователя для 
связи с локальным сервером, удаленным сервером или 
большой ЭВМ. Ыоѵеіі также предоставляет програм- 
мное обеспечение управления сетью, которое облег- 
чает работу администратора сети. 

Соединение с системами ІВМ $ЫА 

Архитектура операционной системы ЫеіѴѴаге ѵЗ.11 
фирмы Ыоѵеіі обеспечивает улучшенную связь ЛВС с 
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главными системами на основе служб КеПѴаге Согп- 
типісаііоп Зегѵісез. Это позволяет реализовывать та- 
кие продукты, как ЫеПУаге Гог ЗАА, в виде загружа- 
емых модулей Ые1>Ѵаге ШЬМ) и выполнять их в каче- 
стве надстройки ЫеГѴѴаге ѵЗ.11. ІЧеПѴаге Гог ЗАА осу- 
ществляет доступ к нескольким главным системам ІВМ 
с одного сервера, обеспечивая оптимальную произво- 
дительность работы нескольких каналов связи с глав- 
ными системами одновременно. 

Продукт ЫеПѴаге 3270 ЬА14 АѴогкзІаІіоп Гог ЭОЗ 
обеспечивает пользователям сети эффективный доступ 
к главным системам ЗЫА через программу ЫеПУаге Гог 
ЗАА или ЫеИѴаге 5М Саіешауз. ЫеІ\Ѵаге ЗЫА Саіе- 
дѵау ЕЬЗ реализует наиболее простое и недорогое ре- 
шение, превращая ІВМ РС, Р5/2 или другую реко- 
мендованную совместимую ПЭВМ в сервер-шлюз ЗЫА. 
Этот шлюз обеспечивает доступ к системам ЗЫА до 16 
пользователей сети и поддерживает коаксиальную и 
удаленную опции соединения. ЫеіѴ/аге ЗЫА Саіечѵау, 
последний продукт в этой группе, позволяет 97 поль- 
зователям сети осуществлять связь с большой ЭВМ 
ІВМ или ЗЫА-соместимой системой, а также со сред- 
ней ЭВМ. Этот шлюз поддерживает удаленное и коак- 
сиальное соединение, а также соединения СоахМих и 
Токеп-Кіпв с главными системами. 

МеЛѴаге 5250 ЬАЫ \ѴогкзІаІіоп обеспечивает поль- 
зователей сети доступом к миниЭВМ ІВМ АЗ/400 или 
ЗузІеш/ЗХ, используя для этого программу ЫеіѴѴаге 
5250 Саіеѵау. Программа ЫеГѴѴаге 5250 Саіеѵ/ау пре- 
вращает персональные компьютеры сети 14еГ\Ѵаге в 
сервер-шлюз, который обеспечивает связь с миниЭВМ 
ЗузІет/ЗХ. Этот шлюз, связанный с ЗузІет/ЗХ 
удаленным соединением ЗПЬС или сдвоенным коакси- 
альным кабелем, позволяет ІВМ РС, Р5/2 Мобеіз 25 и 
30 и совместимым с ними ПЭВМ осуществлять доступ 
к информации и прикладным программам миниЭВМ. 

Соединение 

персональных компьютеров 
с главными системами 

ЫоѵеІІ предлагает два продукта связи персональных 
компьютеров с главными системами: КеіѴ^аге 3270 
МиШ АѴогкзІаІіоп и ЫеПѴаге 3270 СІГГ >Ѵогкз1аІіоп. 
Эти пакеты эмуляции терминала, предназначенные 
для поддержки одного пользователя, позволяют эмули- 
ровать на ІВМ РС, РЗ/2 и совместимых с ними рабо- 
чих станциях терминалы ІВМ. 

МеПѴаге 3270 МиШ АѴогкзІаІіоп поддерживает на 
одной рабочей станции одновременно до пяти сеансов 
печати и диалога с главной системой и один сеанс 
ООЗ. Рабочая станция может быть связана с главной 
системой коаксиальным соединением, соединением 
Токеп-Кіп8 или прямым соединением ЗОЬС. 

ЫеПѴаге 3270 СІІТ ѴѴогкзіаііоп поддерживает один 
сеанс с главной системой и один сеанс ООЗ и связы- 
вается с главной системой прямым коаксиальным со- 


единением, подключаемым к кластерному контроллеру 
3x74 или совместимому с ним. Продукты ЫеЛУаге 
3270 МиШ "ѴѴогкзІаІіоп и МеОѴаге 3270 СІІТ \ѴогкзІа- 
Ііоп продаются и поддерживаются фирмой Ребегаі 
Теспоіоёу. 

Соединения в региональных 
вычислительных сетях 

Продукты для объединения в региональные вычис- 
лительные сети (РВС) позволяют компаниям соеди- 
нять удаленные сети и удаленных пользователей пер- 
сональных компьютеров, эффективно создавая одну 
большую РВС, состоящую из нескольких локальных 
сетей, имеющих различное географическое положение. 
Региональные вычислительные сети предоставляют 
пользователям возможность осуществлять доступ к 
удаленным ресурсам точно так же, как если бы эти 
ресурсы были локальными. Например, сети в реги- 
ональных офисах могут быть объединены в городскую, 
национальную или глобальную сеть, включающую 
также сеть в штаб-квартире компании. Такие соеди- 
нения обычно имеют несколько видов линий связи: 
коммутируемые линии, общественные или частные се- 
тевые службы коммутации пакетов, прямые цифровые 
службы и линии Т1. 

Выбор решения для РВС 

Существуют различные продукты объединения в ре- 
гиональные сети, отличающиеся по производительно- 
сти и функциональным возможностям. Поскольку для 
каждой сети характерны специфические требования, 
менеджеры сети должны учесть несколько факторов 
перед тем, как выбрать решение для РВС. Эти фак- 
торы включают: 

- вид прикладных программ; 

- вид соединения; 

- техническую поддержку. 

Прикладные программы РВС различаются по объе- 
мам и частоте доступа к удаленным сетям. Объем и 
частота доступа к удаленным сетям определяют необ- 
ходимое решение для РВС. Например, электронная 
почта обычно использует передачу с промежуточным 
хранением данных, которая не требует постоянного 
соединения между сетями в режиме реального вре- 
мени. Если прикладные программы электронной по- 
чты используются вместе с другими прикладными про- 
граммами, которые не создают высоких нагрузок, то 
можно использовать большинство видов соединений, 
применяющихся в региональных вычислительных се- 
тях. Для прикладных программ, требующих доступа к 
главным системам, администраторы сети могут уста- 
новить централизованный шлюз для локальных и уда- 
ленных пользователей. При этом на рабочих станциях 
пользователей должна выполняться программа эмуля- 
ции терминала, осуществляющая доступ к главной си- 
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стеме через шлюз, который установлен в удаленной 
сети. 

Если пользователям необходимо только эмулировать 
терминал, нагрузка на канал будет сравнительно не- 
большой, поскольку передаваться будут только введен- 
ные с клавиатуры символы и информация, формиру- 
ющая экран. Однако, если пользователям необходимо 
иметь широкие возможности передачи файлов, на- 
грузка на шлюз и канал будет высокой, что требует 
высокой роизводител ьного решен ия . 

Передача файлов — наиболее простая задача из 
тех, которые выполняются в РВС. Передача файла из 
одной сети в другую использует однонаправленную 
связь; пользователь, посылающий информацию, может 
завершить транзакцию, не дожидаясь ответа прини- 
мающей сети. Поскольку в данной ситуации не требу- 
ется интерактивного взаимодействия между двумя се- 
тями в режиме реального времени, линии связи с низ- 
кой пропускной способностью обычно оказываются до- 
статочными. Однако, если канал связи загружен, а 
файлы имеют большие размеры, передача файла мо- 
жет занять много времени. В такой ситуации может 
потребоваться использование высокопроизводительной 
линии связи между двумя узлами сети. 

Прямой доступ к файлам может создать существен- 
ную нагрузку на канал связи РВС, особенно если 
пользователям часто требуется осуществлять доступ к 
данным удаленной сети. Использование в такой ситу- 
ации каналов связи с низкой производительностью 
может оказаться неприемлемым для пользователей, 
привыкших получать доступ к данным при работе с 
той же самой прикладной программой со скоростью, 
поддерживаемой в ЛВС. В результате прямой доступ к 
файлам обычно требует использования каналов, свя- 
зывающих две сети со скоростью, превышающей 
1 Мбит/с. 

Производительность региональных вычислительных 
сетей обычно измеряется в терминах пропускной спо- 
собности используемых соединений. Наиболее распро- 
странены следующие скорости передачи: от 2400 до 
9600 бод (низкая производительность), 56 Кбит/с 
(средняя производительность) и линия Т1 (высокая 
производительность). Два фактора помогут админи- 
страторам сети определить скорость передачи, необхо- 
димую для их сети: вид прикладных программ и число 
пользователей на один канал связи. Таблица 2.2 мо- 
жет служить руководством при выборе скорости пере- 


дачи линии связи в зависимости от поддерживаемых 
прикладных программ РВС. 

После того, как администратор сети определил не- 
обходимую скорость передачи, он должен выбрать 
среду передачи, по которой будет осуществляться 
связь. Существуют несколько стандартных сред пере- 
дачи, которые включают асинхронные линии связи, 
прямую цифровую службу (ОЭЗ), линии Х.25 и ли- 
нии Т1. Все эти среды отличаются по скорости пере- 
дачи информации, надежности и стоимости. 

Асинхронные соединения работают на скорости до 
19,2 Кбит/с. Они предназначены для использования в 
сетях с низкими нагрузками, редким доступом и для 
организации связи между двумя узлами. Соединения 
Х.25 могут быть легко установлены и демонтированы, 
что обеспечивает большую гибкость. Соединение осу- 
ществляется через сети передачи данных. Каналы Х.25 
требуют выделенного или коммутируемого соединения 
с общественной сетью передачи данных (РОЮ. После 
того, как связь с РОЫ установлена, информация пере- 
дается по ней к пункту конечного назначения. 

Линии прямой цифровой службы ШП$) работают 
на скоростях передачи до 56 Кбит/с (в США) и до 
64 Кбит/с (в Европе). Поскольку в этих линиях 
используются синхронные протоколы, они отличаются 
более высокой надежностью, но их реализация обхо- 
дится дороже. Линии ЭОЗ хорошо подходят для 
использования в сетях с удаленным доступом средней 
интенсивности, включающим передачу файлов и ред- 
кий прямой доступ. 

Линии Т1 обеспечивают скорость передачи до 
1,544 Мбит/с (США) и 2,048 Мбит/с (СЕРТ-Европа). 
Поскольку линии Т1 стоят дорого, их рекомендуется 
устанавливать только в сетях, требующих высокой 
производительности каналов связи. Полностью исполь- 
зуемые линии Т1 могут обеспечить пропускную спо- 
собность, приближающуюся к пропускной способности 
некоторых сетей, что позволяет многим прикладным 
программам выполняться практически без проблем, 
связанных с производительностью. Линии Т1 поддер- 
живают также “частичные 1 * скорости, что позволяет 
разделять их на несколько каналов: для данных, 
аудио- и видеоинформации. 

Хотя производительность, вид прикладных про- 
грамм и потребности пользователей имеют определя- 
ющее значение при выборе линии связи в РВС, мене- 
джеры должны учитывать такой фактор, как степень 
поддержки, необходимой для каждого вида связи. 
Асинхронные соединения между двумя узлами не 
требуют большого внимания при эксплуатации. С 
другой стороны, региональная вычислительная 
сеть, соединяющая две крупных сети, несколько 
небольших сетей, десятки файловых серверов и 
тысячи рабочих станций, требует больших затрат 
на поддержку и эксплуатацию. Затраты на экс- 
плуатацию большинства региональных вычисли- 
тельных сетей укладываются между двумя этими 
крайними вариантами. 


Таблица 2.2 


Прикладная программа 


Скорость канала 



19.2 Кбит/с 56 Кбит/с 

Т1 

Электронная почта 

Да 

Да 

Да 

Доступ к главной системе 

Да 

Да 

Да 

Передача файлов 

Да 

Да 

Да 

Прямой доступ к файлам 




данных 

Нет 

Нет 

Да 

Управление 

Да 

Да 

Да 
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Продукты ЫеПѴаге 
для региональных 
вычислительных сетей 

Для обеспечения связи в региональных вычисли- 
тельных сетях ЫеіАѴаге Азупсбгопоиз Кетоіе Вгій^е 
позволяет установить несколько асинхронных линий 
связи, подключенных к одной или нескольким удален- 
ным сетям. ЫеІ\Ѵаге Упк/Х.25 может соединять сеть 
ЦеЦѴаге одновременно с 11 удаленными сетями, 
используя общественные сети данных Х.25. 14еіМ^аге 
Упк/64 соединяет удаленные сети по синхронным 
линиям связи со скоростью от 9600 бит/с до 
64 Кбит/с. Высокопроизводительный продукт Ые(\Ѵаге 
Упк/Т1 также соединяет удаленные сети по синхрон- 
ным линиям связи, но поддерживает скорости до 
2,048 Мбит/с. 

Программа МеІ\Ѵаге Х.25 Саіешау, используемая 
вместе с адаптером Моѵеіі Х.25 Абаріег, превращает 
рабочую станцию сети ЦеГѴѴаге в сервер-шлюз Х.25. 
Она позволяет нескольким пользователям Ые!\Ѵаге 
одновременно использовать одну линию связи с сетью 
пакетной коммутации Х.25, что обеспечивает доступ к 
множеству главных систем и общественных баз дан- 
ных всего мира. Программа Ме1\Ѵаге х.25 Саіеѵ/ау в 
настоящее время продается и поддерживается фирмой 
Ребега! ТесНпоУ^у. 

Моѵеіі предлагает два вида средств, обеспечива- 
ющих подключение удаленных персональных компью- 
теров к сети ЫеПѴаге. ЫеіѴѴаге Ассезз Зегѵег позволяет 
подключаться к сети ЫеПѴаге 15 удаленным пользова- 
телям и осуществлять доступ к прикладным програм- 
мам, электронной почте, а также к соединениям с 
большими или миниЭВМ. 

Передача сообщений в Иеі\Уаге 

За последние несколько лет мы стали свидетелями 
стремительного роста использования служб электрон- 
ной передачи сообщений. Сервер сети стал общепри- 
нятым средством поддержки этих служб. Целью Моѵеіі 
является создание надежной службы передачи сообще- 
ний для обеспечения связи во всей организации на 
основе широкого спектра имеющихся и разрабатыва- 
емых стандартов. Службы передачи сообщений обес- 
печиваются 14е1\Ѵаге МНЗ 

Ыеі\Ѵаге МНЗ (Мезза^е Напбііпе Зегѵісе — служба 
управления сообщениями) позволяет нескольким про- 
граммам предварительной обработки осуществлять 
связь друг с другом с целью выполнения общих задач, 
совместного использования информации или коорди- 
нации действий в локальных или региональных вы- 
числительных сетях. 19еГ\Ѵаге МНЗ использует пре- 
имущества технологии промежуточного хранения для 
обеспечения более совершенного обмена сообщениями 
между прикладными программами или процессами, 
выполняющимися в сети. Технология промежуточного 
хранения также снижает затраты на связь, поскольку 


пользователь может указать время, когда передача со- 
общения будет экономически наиболее эффективной. 
Плата взимается только за реальное время передачи 
сообщения по линиям, а не за время открытия линий 
связи в ожидании приема сообщений. 19еі\Ѵаге МНЗ 
выполняется автономно на персональном компьютере, 
не требуя вмешательства пользователя, и использует 
сетевые ресурсы только для сбора или доставки сооб- 
щений. 

Поскольку ни одна система электронной почты не 
распространяется на все вычислительные установки, 
ЫеІ'ѴѴаге МНЗ может интегрировать различные почто- 
вые системы на основе базовой системы организации, 
обеспечивая таким образом совместимость почтовых 
систем для всей организации. Более 40 разработчиков 
прикладных программ, шлюзов и утилит поддержи- 
вают ЫеЛѴаге МНЗ. Шлюзы МНЗ, выпускаемые дру- 
гими поставщиками, обеспечивают соединение с си- 
стемами Х.400, РКОРЗ фирмы 1ВМ, Ш9ІХ, АП-іп-1 
фирмы ЦЕС, ѴМЗМаіІ, МСІ Маіі, Еазуііпк (\Ѵез1егп 
Цпіоп), а также с телексом, факсимильными аппара- 
тами и голосовыми почтовыми системами. 

Средства управления сетью 

Подход Ыоѵеіі к управлению сетью основывается на 
возможностях и гибкости, присущих архитектуре Іпіе- 
ЕгаІеО СотриІіпЕ АгсНіІесіиге. Операционная система 
ЫеЦѴаге ѵЗ.х интегрирует наиболее распространенные 
операционные системы настольных ПЭВМ для созда- 
ния среды управления клиент-сервером, обеспечива- 
ющей распределенные прикладные программы и базы 
данных, интеграцию программ управления других по- 
ставщиков и взаимодействие различных предприятий в 
области управления сетью. Такой подход облегчает со- 
здание модульной системы управления, которая может 
быть адаптирована к конкретному виду сети и много- 
образию организаций, свойственному современной 
среде обработки данных. 

Поскольку архитектура сетевого управления Ыоѵеіі 
основана на ЫеЦѴаге, она может использовать пре- 
имущества передовых средств и методов обеспечения 
взаимодействия, предлагаемых распределенной архи- 
тектурой. Используя базовые элементы архитектуры 
Іпіеегаіесі Сотриііпе АгсЬИесШге фирмы Ыоѵеіі, такие 
как управление файлами и записями, защита инфор- 
мации, устойчивость к сбоям системы, система связи и 
передачи сообщений, а также возможности ядра про- 
токолов ЦеІѴѴаге, менеджеры информационных систем 
получают целый ряд преимуществ. 

Использование распределенных ресурсов ЫеіѴѴаге 
позволяет менеджерам информационных систем при- 
менять стандартные настольные системы, экономя ка- 
питальные вложения и обеспечивая возможность 
управления с любого узла сети, включая удаленные 
соединения, а не со специальной рабочей станции. 
Это одновременно способствует централизации и рас- 
пределению ответственности за управление. 


КомпьютерПресс 4'92 






Сберечь глаза, сидя перед компьютером по 8 часов в день - 
проблема. Саммит Системе - это идеальное разрешение 
ваших проблем! 

о Ваши потребности растут? 

Наш компьютер совершенствуется! 

о Надежность под знаком 
Іпіеі, СНІР5, Оиапіит, Золу 

о ЗирегѴСА монитор 
1024x768 (256 цветов) 

о 2 года гарантии 


Поставьте Будущее Себе на Стол. 




СЕТИ 


45 


Решения 14оѵе11 в области управления направлены на 
обеспечение администраторам информационных си- 
стем улучшенного доступа к информации о сетях 
ЫеЛѴаге и ресурсах. Прикладные программы управле- 
ния сетью, взаимодействующие со средствами управ- 
ления Моѵеіі, будут разделять общие функциональные 
возможности сервера или настольной системы, обеспе- 
чивая взаимосвязанный набор служб управления. 
Средства управления Моѵеіі будет поддерживать 
открытые интерфейсы для интеграции служб управле- 
ния других поставщиков и систем управления пред- 
приятиями. Приоритетной задачей Моѵеіі является 
разработка прикладных программ для управления 
сетями МеіАѴаге. Эти прикладные программы будут 
обеспечивать следующие функциональные возмож- 
ности: 

- текущий контроль. Постановка в очередь или 
асинхронный прием сообщений, аварийных сигналов 
и статистической информации, поступающей от 
управляемых ресурсов независимо от их расположе- 
ния в сети. Ведение базы данных контроля, содер- 
жащей информацию о ресурсах и состоянии сети; 

- задание конфигурации и управление. Динами- 
ческое изменение сетевых ресурсов и параметров, 
включая возможность активизации или дезактивиза- 
ции удаленных ресурсов; 

- устранение неисправностей. Выявление, лока- 
лизация и устранение неисправностей, возникающих 
в любом месте сети; 

- управление изменениями. Обеспечение автома- 
тизированных инструментов модернизации про- 
граммных компонентов сети. 

Реализация функций сетевого управления как 
встроенной компоненты продуктов линии ЫеГѴѴаге 
всегда рассматривалась фирмой Моѵеіі как важная за- 
дача. Уже в первый продукт ЫеГѴѴаге, появившийся на 
рынке в 1982 году, Моѵеіі включила возможности 
управления сетью, реализованные в виде утилит ад- 
министратора РСОМЗОЬЕ, 8Ѵ5СОМ и РІЬЕК. Сегодня 
администраторы информационных систем могут по- 
строить систему управления сетью, комбинируя про- 
дукты управления, поставляемые Моѵеіі. Нынешние 
продукты Моѵеіі разработаны на основе архитектуры 
клиент-сервера (Іпіебгаіесі СошриИп^ АгсЬііесІиге) 
фирмы Моѵеіі. Все продукты управления отвечают 
промышленным стандартам для обеспечения взаимо- 
действия и интеграции лицензионных систем. 

Комбинирование нынешних продуктов Моѵеіі — 
первый шаг на пути к созданию интегрированной си- 
стемы управления неоднородными сетевыми средами. 
Нынешние продукты управления сетью Моѵеіі вклю- 
чают: 

- ІАМаІгуег Меіѵ/огк Апаіугег; 

- ЬАМіегп пебѵогк топііогіп§ зузіет; 

- МеіѴ/аге Мате Зегѵісе. 

Средства управления сетью МеЛѴаге ѵЗ.11 содер- 
жат: 

- Кетоіе Малагетеп» РасіШу(КМР); 

- поддержку МеіѴіеш; 


- поддержку ЗММР; 

- МеЛѴаге тапаеетепі иШНіез. 

По мере реализации стратегии управления Моѵеіі 
будут появляться новые продукты, которые дополнят 
существующие до целостной системы управления 
всеми компонентами ЛВС и службами сети. 

РАЗРАБОТКА 
ПРИКЛАДНЫХ ПРОГРАММ 
КЛИЕНТ-СЕРВЕРА 


Сетевые приложения становятся наиболее мощными 
тогда, когда прикладные программы клиент-сервера 
используют преимущества базовых служб сети, предо- 
ставляемых операционными системами МеГѴѴаге. Тра- 
диционно сети использовались как инструмент обеспе- 
чения связи и совместного доступа к данным. Но по 
мере того, как сети становятся важной частью биз- 
неса, возникает необходимость поддержки в них воз- 
можностей, необходимых для прикладных программ 
клиент-сервера. 

Инструменты разработчика 
баз данных 

Прикладные программы управления данными — 
первые кандидаты для распределенной обработки в 
архитектуре клиент-сервера ЫеіѴ/аге. Архитектура 
клиент-сервера позволяет различным прикладным про- 
граммам одновременно использовать общую базу дан- 
ных, а также во многих случаях, мощные процессоры 
сервера 386 или 486. Перенос программ управления 
данными с рабочих станций на сервер способствует 
высвобождению ресурсов рабочих станций. Такая ар- 
хитектура позволяет также выборочно централизовать 
самые важные функции управления данными, такие 
как защита информации баз данных, обеспечение це- 
лостности данных и управление совместным использо- 
ванием ресурсов. 

Другим важным преимуществом архитектуры кли- 
ент-сервера в управлении данными является возмож- 
ность увеличения производительности. Предположим, 
что прикладная программа базы данных загружена на 
рабочую станцию и пользователь хочет распечатать 
все записи, удовлетворяющие заданному набору кри- 
териев. В среде традиционного файлового сервера про- 
грамма управления данными, выполняющаяся на ра- 
бочей станции, должна осуществлять запрос к серверу 
для каждой записи базы данных, как показано на 
рис. 2.2. Программа управления данными на рабочей 
станции сможет определить, удовлетворяет ли запись 
критериям, только после того, как эта запись будет 
передана на рабочую станцию. Записи, удовлетворя- 
ющие критериям, возвращаются программе предвари- 
тельной обработки. Этот процесс может вылиться в 
сотни и даже тысячи операций передачи в сети. 
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КАТАЛОГ ПРОДУКТОВ ФИРМЫ ІЧОѴЕІХ 


Важно учитывать возможность увеличения трафика 
данных в сети, работая с большими базами данных. В 
среде клиент-сервера, напротив, рабочая станция по- 
сылает запрос высокого уровня серверу базы данных. 
Если речь идет о реляционной базе данных, запрос 
почти наверняка будет представлять собой оператор 
языка структурированных запросов ($(}І.), содержа- 
щий критерий выбора. — это язык высокого уров- 
ня, позволяющий определять и обновлять реляционные 
базы данных, а также осуществлять доступ к ним, 
ставший широко распространенным стандартом. 

Сервер баз данных осуществляет поиск записей на 
диске и применяет к ним критерии ограничения. За- 
писи, удовлетворяющие критериям, могут быть накоп- 
лены на сервере. После того, как запрос целиком 
обработан, клиенту возвращаются только записи, удо- 
влетворяющие критериям. Это позволяет снизить сете- 
вой трафик и повысить пропускную способность сети. 
Более того, за счет выполнения операции доступа к 
диску и обработки данных на одной системе (обычно 
это высокопроизводительная миниЭВМ с быстрыми 
дисками и большим объемом кэш-памяти) сервер мо- 
жет осуществлять поиск и обрабатывать запросы бы- 
стрее, чем если бы эти запросы обрабатывались на ра- 
бочей станции. 

Поддержка прикладных программ баз данных кли- 
ент-сервера обеспечивается двумя продуктами: Ые!- 


Ѵ(аге Вігіеѵе и ЫеіѴ/аге ЗОЕ Вігіеѵе представляет со- 
бой программу управления записями с индексацией по 
ключу выполняющуюся на сервере, а ЫеІ'ѴѴаге — 
ядро реляционных баз данных, обеспечивающее стро- 
гую систему защиты и целостность данных. Реализо- 
ванные в конфигурациях ѴАР и N04, эти два про- 
дукта предназначены для использования в качестве 
прикладных программ обработки, обеспечивающих 
операции сервера баз данных для программ предвари- 
тельной обработки других поставщиков. Коѵеіі также 
предлагает версии ЫеІѴѴаге Вігіеѵе и КеіѴ/аге 5()Ь, 
работающие на рабочих станциях. Версии этих про- 
грамм для клиентов работают в различных средах ра- 
бочих станций. 

Службы баз данных ЫеЛѴаге Вігіеѵе и №і\Ѵаге 
фирмы Коѵеіі позволяют разработчикам создавать на- 
дежные прикладные программы баз данных без необ- 
ходимости написания собственных программ управле- 
ния записями и ядра реляционной базы данных, что 
особенно важно для программистов, испытывающих 
дефицит времени. Однако эти средства решают еще 
более важную задачу. 

Одна из наиболее серьезных проблем, с которой 
сталкиваются разработчики прикладных программ баз 
данных, — это переход к реализации клиент-сервера. 
Этот переход не только требует огромных затрат вре- 
мени, но может привести к существенному увеличе- 
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Рис. 2.2 Сокращение трафика 
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нию стоимости разработки в результате проблем пере- 
дачи, которые добавляет разработчикам прикладная 
программа сервера. 

Посредством ЫеІ'ѴѴаге Вігіеѵе и ЫеІ'ѴѴаге ВДЬ фирма 
Ыоѵеіі обеспечивает удобный перенос прикладных про- 
грамм баз данных в среду клиент-сервера. Существуют 
тысячи прикладных программ, написанных для авто- 
номных, многозадачных и ориентированных на кли- 
ента версий ЫеіѴѴаге Вігіеѵе и ЫеіѴѴаге 5(}Ь. Работая 
совместно с ЫеІ'ѴѴаге Вігіеѵе Кециезіег или ЫеіѴѴаге 
5(ЗЬ Кедиезіег, большинство прикладных программ 
могут автоматически стать прикладными программами 
сервера, без необходимости их модификации. Более 
того, версии ЫеіѴѴаге Вігіеѵе и ЫеіѴѴаге 5>(2Б для кли- 
ентов имеют согласованные АРІ, что упрощает пере- 
нос прикладных программ из среды одного клиента в 
среду другого клиента. 

Средства обеспечения связи 
и стандартные протоколы 

Поощряя разработку распределенных прикладных 
программ, поддерживающих основные стандарты связи 
и стандартные протоколы, Ыоѵеіі предлагает следу- 


ющие инструментальные средства: ЫеІ\Ѵаге КРС, ТС- 
РоП, БАМ ѴѴогкРІасе, ЫеіѴѴаге Ш6.2 и ЫеіѴѴаге 3270. 

Ыоѵеіі также обеспечивает разработчиков наборами 
8о(і\ѵаге Оеѵеіорег'з Кііз (ЗОЮ. БОК — это готовящи- 
еся к выпуску инструментальные средства программи- 
рования фирмы Ыоѵеіі, содержащие ПО для создания 
прикладных программ, ориентированных на ЫеіѴѴаге. 
Версии БОК для нескольких сред клиентов можно по- 
лучить, приняв участие в программе Ргоіеззіопаі Ое- 
ѵеіорегз Рго^гат. За дополнительной информацией об 
этой программе или $ОК следует обращаться в группу 
Оеѵеіорег Кеіаііопз Сгоир по телефону 1-800-КЕО- 
ѴѴОІШ [(800) 733-9673]. 

Сетевые интерфейсы 
прикладного программирования 

Деятельность Ыоѵеіі направлена на стимулирование 
разработки прикладных программ, способных выпол- 
няться в сетях ЫеіѴѴаге. Поощряя создание сетевых 
прикладных программ, фирма Ыоѵеіі обеспечивает 
разработчиков компиляторами и интерфейсами при- 
кладного программирования (АРІ), которые снижают 
стоимость разработки и упрощают ее процесс. 


Рара(^рарн 


Совместное предприятие "Параграф” предлагает 

Русифицированные версии программных продуктов мирового класса: 

РусскоеСлово 2.0 

включает текст-процессор Місговоіі Ѵ/огсІ 5.0 

Русский Парадокс 

включает СУБД Рагасіох 3.5 (Вогіапб Іпі.) 

Русский ОиаНго Рго 

включает электронные таблицы ОиаНго Рго 3.0 (Вогіапб Іпі.) 

Резидентные русификаторы М 8 \Ѵіп(іоѵѵ 5 и N01100 Сотшапсіег 

РагаТуре 

шрифты для лазерных принтеров в форматах: НР І.а$ег іеі и РохіЗсгірІ. 

Электронный секретарь 

программно-аппаратный комплекс обработки звука и автоматизации телефонной коммуникации. 


Наш адрес: 103051, Москва, Петровский бульвар, 23. 
Телефоны: (095) 200-25-66, 924-17-81. Факс: (095) 928-27-68. 
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ІМАОЕК - ГРАФИКА ДЛЯ ЕСА/ѴОА 

Пакет ІМАОЕК предназначен для разработчиков 
программного обеспечения, работающих с графикой 
ЕСА/ѴОА. 

С помощью пакета ІМАОЕК можно: 

Легко и быстро оформить пользовательский интерфейс. 

Разработать и включить в прикладную программу различные 
изображения, пиктограммы, произвольные шрифты, включая 
национальные и специализированные. 

Подготовить и отладить мультипликационные фрагменты 
и различные заставки. 

Специальный раздел, посвященный построению и работе 
с кривыми, может найти самое широкое применение в научных 
и обучающих приложениях. 

Пакет ІМАСЕК — путь к новым принципам построения 
графических интерфейсов, идущих на смену набившим оскомину 
“меню". 

Отличительная особенность пакета ІМАСЕК — работа с текстами 
Ваших программ и с текстами описаний Ваших изображений. 

Наибольшие преимущества при работе с ІМАСЕК получают 
пользователи пакета (^шск С (МісгозоЙ С), но особенности пакета 
делают его применение выгодным как пользователям других систем 
С, так и программистам на Паскале, БЕЙСИКе и остальным. 

Пакет ІМАСЕК прост в управлении и эффективен в работе. 

Он будет полезен как начинающим, так и квалифицированным 
программистам. 

В пакет ІМАСЕК включены исходные тексты основных функций — 
пакет открыт для модификаций. 

Цена пакета 1660 рублей. 

ЕСА/ѴОА — ГРАФИКА — ІМАСЕК 

Все справки, заказы на изготовление программной продукции, информацию 
по вопросам приобретения Вы можете получить по телефону 

(095)140-06-58 

или по адресу 

121467 Москва, а/я 151 
НПК “ Микропроцессорные системы “ 
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ІДе/іь данной статьи — обобщение 
опыта изучения некоторых 
существующих защит от стандартных 
дизассемблеров и отладчиков 
и .получение на основе его анализа 
рекомендаций по написанию модулей 
защиты от названных средств 
исследования программ. 


Защита программ 
от дизассемблеров и отладчиков 


Практика показывает, что задача дизассемблирова- 
ния, для решения которой часто требуется привлекать 
отладочные средства, и задача анализа программ стан- 
дартными отладчиками тесно взаимосвязаны. Это по- 
зволяет рассматривать их совместно в одной статье. 

Для более легкого восприятия материала выбрана 
следующая логика его изложения. Первый раздел по- 
священ описанию некоторых принципов вскрытия за- 
щит стандартными средствами анализа программ и 
проблемам, с которыми сталкивается при этом хакер. 
Во втором разделе речь пойдет об основных методах 
противодействия вскрытию защитных механизмов про- 
грамм, и будут рассмотрены некоторые практические 
приемы их реализации. 

Защита программ 
с точки зрения хакера 

Наличие механизмов защиты от дизассемблеров и 
отладчиков в исполняемом модуле исследуемой про- 
граммы становится первым и, пожалуй, наиболее 
сложным препятствием для хакера (взломщика). За- 
дача таких механизмов защиты — недопущение или 
максимально возможное затруднение анализа испол- 
няемого кода программы. Средства защиты от стан- 
дартных дизассемблеров и отладчиков должны быть 
неотъемлемой частью любого профессионального 


пакета защиты программ от возможных несанкциони- 
рованных вмешательств. 

Вполне объяснимо желание программиста работать 
с твердой копией исследуемой программы. Поэтому 
одной из проблем, с которыми сталкивается хакер при 
взломе практически любой защиты, является диза- 
ссемблирование исполняемого кода программы с 
целью получения его ассемблерного листинга. 

Сложность решения данной проблемы обусловлена 
использованием в программах разнообразных способов 
скрытия их исходного текста от стандартных средств 
дизассемблирования. Наиболее распространенные ме- 
тоды скрытия — шифрование и архивация (как раз- 
новидность шифрования). Применения простейших их 
видов уже достаточно для достижения цели. Непосред- 
ственное дизассемблирование защищенных таким спо- 
собом программ, как правило, не дает верных резуль- 
татов, если вообще что-либо дает. Очевидно, хакеру в 
данной ситуации необходимо прибегнуть к каким-либо 
отладочным средствам для снятия программного 
шифра. Обычно это сделать несложно, так как за- 
шифрованная или архивированная программа чаще 
всего выполняет обратную операцию (дешифрацию) в 
первых же командах, на которые передается управле- 
ние сразу после запуска программы. Определив мо- 
мент дешифрации, можно программными средствами 
“снять" в файл дамп памяти, занимаемой преобразо- 
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ЗАЩИТА ПРОГРАММ ОТ ДИЗАССЕМБЛЕРОВ И ОТЛАДЧИКОВ 


ванной программой, и, прогнав его через какой-либо 
дизассемблер, получить желаемый результат. 

Дело значительно усложняется, если защитный ме- 
ханизм использует поэтапную дешифрацию про- 
граммы. Это значит, что программа дешифруется не 
сразу в полном объеме, а отдельными участками и в 
несколько этапов, разнесенных по ходу работы про- 
граммы. При этом защита от дизассемблера оказыва- 
ется распределенной по времени. 

В такой ситуации может быть использован следу- 
ющий алгоритм устранения защиты. В первую очередь 
необходимо попытаться выяснить при помощи отла- 
дочных средств, существует ли какая-либо подпро- 
грамма или общий участок программы, осуществля- 
ющие дешифрацию. Если существует, то, запуская 
под отладчиком подпрограмму дешифрации требуемое 
количество раз с необходимыми входными парамет- 
рами, можно получить полностью дешифрованную 
программу. Если же дешифрацию выполняют не- 
сколько различных подпрограмм или участков про- 
граммы, то вам предстоит очень нудная и кропотливая 
работа по их выявлению, а затем поочередному и ак- 
куратному запуску под отладчиком. 

После вскрытия защиты не забудьте заблокировать 
каким-либо способом работу подпрограммы дешифра- 
ции при запуске дешифрованной программы. Напри- 
мер, это можно сделать путем изменения подпро- 
граммы дешифрации таким образом, чтобы после 
входа в нее сразу же осуществлялся выход с требу- 
емым кодом возврата. 

Если размер исследуемой программы невелик и ва- 
ши усилия по ее дизассемблированию стандартными 
средствами оказались тщетны, то анализ исполняемого 
кода защиты удобно проводить при помощи отладчи- 
ка, так как он позволяет дизассемблировать программу 
с любого адреса. В качестве универсального дизассем- 
блера можно порекомендовать отладчик ТигЬо ЭеЪиб- 
8ег (ТО), обладающий очень широким набором воз- 
можностей и удобным пользовательским интерфейсом. 

Проблема преодоления защитных механизмов, на- 
целенных на недопущение исследования программ 
стандартными отладочными средствами, не менее 
сложна и, на наш взгляд, небезынтересна разработ- 
чику средств защиты. Очень много хлопот при реше- 
нии этой проблемы может доставить стек, а именно, 
его расположение в исследуемом модуле, размер, ха- 
рактер использования программой и т.п. Защитные 
механизмы, тонко использующие стек, зачастую де- 
лают практически невозможным применение стан- 
дартных отладочных средств для анализа своего кода. 

Примером защитного использования стека может 
служить его назначение в тело выполняемой задачи. 
Для этого стековый сегмент должен совпадать с кодо- 
вым, а указатель вершины стека 5Р должен указывать 
в область исполняемого кода программы. Тогда обра- 
ботка отладчиком первого же прерывания (скажем, 
трассировочного) обязательно приведет к затиранию 
небольшого (а иногда и большого) участка программы 
(не менее 3 слов, необходимых для входа в прерыва- 


ние). Например, такие широко известные отладчики, 
как ТЭ и Со(іеѴіе\ѵ, используют для своей работы 
только пользовательский стек и, следовательно, зати- 
рают его на наибольшую глубину. Кроме того, отлад- 
чик ТЭ (по крайней мере, его старые версии) имеет 
принципиальную ошибку в отношении использования 
стека. При начальной загрузке программы он совер- 
шенно бесцеремонно уменьшает стартовое значение 
указателя стека на 2. Более умеренно работают с 
пользовательским стеком отладчики АРЭ и 
РЕКІ5СОРЕ. Наиболее выгодно проявляет себя в этом 
отношении стандартный отладчик ООЗ ОЕЕШС. 

Бороться с назначением стека в тело программы 
можно путем переназначения его в свободную область 
памяти вне программы. Такой подход возможен только 
в случае, если стек используется защищенной про- 
граммой с единственной целью сохранения данных. 
Дело значительно усложняется, когда стек не только 
содержит массивы данных для текущей работы, но и 
сам в ней активно участвует. Так, например, в защит- 
ном механизме, формируемом пакетом ССШѴОѴ 
фирмы “Элиас“, через стек осуществляется разархи- 
вирование файла. В такой ситуации выход может быть 
только один: проход участков программы, использу- 
ющих стек, без трассировки, то есть не в пошаговом 
режиме. Наиболее радикальный метод анализа подо- 
бных защитных механизмов — использование нестан- 
дартных средств отладки, например, эмуляторов ра- 
боты процессора. Однако данная тема выходит за 
рамки нашей статьи. 

Другой важной и не менее сложной проблемой, 
возникающей при исследовании механизмов защиты 
от стандартных отладочных средств, становится 
отслеживание прерываний, перехватываемых исследу- 
емой программой. Суть проблемы заключается в сле- 
дующем. Практически все стандартные отладчики для 
обеспечения своей нормальной работы “забирают" как 
минимум прерывания 01 Н и ОЗН. Прерывание 01 Н, 
называемое также трассировочным, используется для 
обеспечения пошагового режима работы отладчика. 
Прерывание ОЗН необходимо для установки меток 
останова программы по адресам, определяемым поль- 
зователем. 

Защитный механизм программы обязательно дол- 
жен перехватывать указанные прерывания для предот- 
вращения беспрепятственного анализа кода защищен- 
ной программы под отладчиком. Поэтому очередной 
задачей хакера на данном этапе является отслежива- 
ние момента перехвата. Если эта задача решена, то 
далее он может продвигаться по одному из двух путей. 

Во-первых, можно запретить перехват прерываний 
путем обхода данного участка программы. В этом есть 
определенная доля риска, так как подпрограммы обра- 
ботки захватываемых прерываний могут выполнять и 
некоторые “полезные" функции, необходимые для 
нормальной работы основной программы. И все же та- 
кой способ решения может оказаться вполне пригод- 
ным (например, при изучении работы защитного 
механизма пакета СОРѴШСК). 
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Если этот “номер“ не прошел, то можно пойти по 
второму пути. Необязательно запрещать перехват пре- 
рываний. Если ваша квалификация достаточно высока 
и защитный механизм программы позволяет это сде- 
лать, можно изменить подпрограммы обработки пре- 
рываний так, чтобы после отработки своих функций 
они не сразу возвращали бы управление в основную 
программу, а передавали его соответствующим под- 
программам отладчика. 

Конечно же, приведенный перечень проблем, с ко- 
торыми хакер может столкнуться при исследовании 
механизмов защиты от стандартных средств анализа 
программ, далеко не полон (ниже мы еще рассмотрим 
некоторые из них). Но описанные методы анализа мо- 
гут оказаться полезными при решении практически 
любых задач и, по нашему мнению, должны быть ин- 
тересны подавляющему большинству программистов. 

Методы противодействия 
анализу программ 

Теперь встанем на сторону разработчика защитного 
механизма и попробуем определить, какими спосо- 
бами можно помешать анализу работы программ, про- 
водимому с помощью стандартных средств дизассем- 
блирования и отладки. 

Несколько методов противодействия дизассемблиро- 
ванию исполняемого кода программы уже были опи- 
саны выше. Дополним их список: 

- шифрование; 

- архивация (как разновидность шифрования); 

- использование самогенерируемых кодов; 

- “обман 1 * дизассемблера. 

Шифрование исполняемого кода программы с 
целью защиты от дизассемблера — наиболее простое 
средство в отношении как реализации, так и снятия. 
Поэтому шифрование может рассматриваться лишь 
как часть механизма защиты и не обязательно должно 
быть сложным. Достаточно, например, к каждому 
байту исполняемого модуля прибавить некоторую кон- 
станту, чтобы дизассемблер ничего “не понял**. 

Предварительная архивация кода программы 
также не представляет особых трудностей для хакера. 
Однако архивация более эффективна по сравнению с 
шифрованием, так как решает сразу две задачи: 
уменьшение размера защищаемого модуля и скрытие 
кода программы от дизассемблера. Методов сжатия 
исполняемых файлов на сегодняшний день известно 
множество. Мы не будем останавливаться на их опи- 
сании, заметим только, что файлы, создаваемые с их 
помощью, должны быть самораспаковывающимися. 

Для усиления защитного действия шифрованного 
кода его дешифрацию желательно выполнять по- 
этапно — на разных участках и в разные моменты ра- 
боты программы. 

Самогенерируемые коды — крайне сложное в 
реализации, но, пожалуй, наиболее эффективное 
средство борьбы с дизассемблерами. Для неискушен- 
ного читателя кратко поясним их суть. 


Самогенерируемые коды — это исполняемые коды 
программы, полученные в результате выполнения не- 
которого набора арифметических и/ или логических 
операций над определенным, заранее рассчитанным 
массивом данных. Самогенерируемые коды вырабаты- 
ваются непосредственно защищаемой программой, ко- 
торая по ходу выполнения как бы сама себя 
“достраивает**. Текст вашей программы выглядит 
по-настоящему красивым и оригинальным, если мас- 
сив исходных данных самогенерируемых кодов подоб- 
ран таким образом, что он сам является исполняемым 
кодом (причем желательно, реально получающим 
управление) или, что, на наш взгляд, еще более кра- 
сиво, неким смысловым текстом. Пример самогенера- 
ции можно обнаружить в защитном механизме, реали- 
зуемом пакетом СОРУЮСК. 

“Обманом** дизассемблера мы называем такой 
стиль программирования, который позволяет “запу- 
тать“ стандартный дизассемблер применением нестан- 
дартных приемов выполнения некоторых команд и на- 
рушением общепринятых соглашений. Наиболее ши- 
рокое распространение получили следующие способы 
“обмана** дизассемблера: 

- использование нестандартной структуры программы; 

- скрытые переходы, скрытые вызовы и возвраты из 
подпрограмм и прерываний; 

- переходы и вызовы подпрограмм по динамически 
изменяемым адресам; 

- модификация исполняемых кодов. 

Первый способ основывается на предположении, 
что программа, не имеющая стандартной сегментации 
(например, у которой отсутствует стековый сегмент), 
может быть неправильно воспринята “умным** диза- 
ссемблером. В связи с этим защитные механизмы про- 
грамм чаще всего располагаются в одном сегменте. 

Для направления дизассемблера по ложному следу 
очень часто применяются скрытые переходы, вызовы и 
возвраты, использующие нестандартные реализации 
команд ЛМР, САІХ, ШТ, КЕТ и 1КЕТ. Для програм- 
мистов, не знакомых с подобными программными 
уловками, приведем несколько примеров. 

1. Скрытый ЛМР 

)тр т тоѵ ах,о(Г$еІ т ;3анести в стек 

ри$Н ах ; адрес метки, 

геі ;Перейти на метку. 

т: т: 


2. Скрытый САІХ 


саіі 5иЬг 


$иЬг: 


тоѵ ах,о(Г$еІ т 
ри$Ь ах 
)тр ыіЬг 
т: 

$иЬг: 


;3анести в стек 
; адрес возврата. 

; Перейти на под- 
; программу. 


3. Скрытый ЮТ 


іпі 1 ЗН 


ри$ЬГ 


;3анести в стек флаги. 
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ризЬ сз ;3анести в стек СЗ. 

шоѵ зі.оіізеі ш ;3анести в стек 
ризН зі ; адрес возврата, 

хог зі.зі 
шоѵ ез,зі 

Ітр сіѵѵогсі ріг ез:[131і*4] 
ш: 

4. Скрытый КЕТ 

геі рор Ьх ;Взять из стека адрес возврата 

]шр Ьх ; и перейти на него. 

5. Скрытый ІКЕТ 

ігеі шоѵ Ьр,$р ;Переход на точку воз- 

рпр дѵѵопі ріг [Ьр] ;врата из прерывания. 

асісі зр,4 ; Точка возврата. 

рорГ 

Переходы и вызовы подпрограмм по динамически 
изменяемым адресам подразумевают модификацию 
байтов адреса перехода или вызова подпрограммы, на- 
ходящихся за первым байтом команды (байтом кода 
операции). Приведем несколько примеров. 

1. Модификация адреса перехода 

шоѵ \ѵогс1 ріг сз:т[1],1234Н Подстановка нового адреса 
ш: ,)тр ріасе 

2. Модификация адреса вызываемой подпрограммы 

шоѵ ѵѵогсі ріг сз:т[1],ез 
шоѵ \ѵогс) ріг сз:т[3],5678Ь 

т: саіі Гаг зиЬг 

Модифицировать адрес гораздо проще, если исполь- 
зовать косвенные переходы и вызовы. Например, 

]тр сі\ѵогс1 ріг сз: [Ьх] 
саіі ѵѵогО ріг ез: [зі] 

Здесь возможности модификации адресов значительно 
шире. 

Описанный прием можно также использовать для 
модификации любых исполняемых кодов. Например, 
общеизвестная однобайтная команда Р115Н АХ имеет 
кодировку 50Н (01010000). Изменив каким-либо спо- 
собом один из битов команды (допустим, 4-й), мы по- 
лучим совершенно другую команду (ШС АХ). Осуще- 
ствить это практически можно, например, так; 

апсі Ьуіе ріг сз:ш,0ЕРЬ ;Обнулить 4-й бит по адресу ш 
ш: ризЬ ах 

После кропотливой работы по данной методике 
можно изменить некоторый участок программы до не- 
узнаваемости. 

Все вышеописанные методы “обмана** дизассем- 
блера рассчитаны на то, что “умный** дизассемблер 
(например, Зоигсег), отслеживая моменты передачи 


управления, не найдет некоторые участки программы 
и соответственно не дизассемблирует их. Особенно 
успешно эта цель может быть достигнута при исполь- 
зовании самогенерируемых кодов и скрытых команд 
ІМР и САН. 

Рассмотрим теперь некоторые методы противодей- 
ствия анализу исполняемого кода, выполняемому при 
помощи стандартных средств отладки. 

Назначение стека в тело программы, как мы уже 
убедились, является очень эффективным средством 
защиты от пошагового выполнения программы отлад- 
чиком. Проблема вскрытия защиты еще более ослож- 
няется, если в целях недопущения переназначения 
стека за пределы исполняемого кода в стек помещены 
данные, необходимые для работы программы. Если к 
тому же вы часто меняете местоположение стека в 
программе, то, поверьте на слово, у хакера, пытающе- 
гося взломать защиту вашей программы, настроение 
будет не лучшим. Ниже мы рассмотрим еще несколько 
способов изматывания хакера. 

Напомним, что при запрещении защитным меха- 
низмом пошагового выполнения программы хакеру ре- 
комендовалось обходить участки перехвата прерыва- 
ния 01 Н. Чтобы такой обход был невозможен, модуль 
защиты должен поручать подпрограмме обработки 
трассировочного прерывания некоторую полезную ра- 
боту. Это может быть, например, генерация участков 
программы, дешифрация и т.п. В такой ситуации ха- 
керу придется кропотливо изучать работу соответству- 
ющей подпрограммы, а это резко увеличивает сроки 
снятия защиты. 

Рассмотрим теперь более традиционные методы 
противодействия стандартным средствам дизассембли- 
рования и отладки, без упоминания о которых наша 
статья была бы неполной. Эти методы достаточно хо- 
рошо известны и широко применяются на практике. 
Ранее они уже были описаны в книге 

Н.Н. Дмитриевского и С.П. Расторгуева “Искусство 
защиты и «раздевания» программ** (Совмаркет, 1991), 
поэтому здесь мы лишь кратко изложим их суть. 

Метод подсчета и проверки контрольных сумм 
определенных участков программы достаточно эффек- 
тивен для отслеживания работы программы под отлад- 
чиком. Этот метод позволяет определить, не установ- 
лена ли в теле проверяемого участка программы кон- 
трольная точка (или точка останова). Как мы уже 
говорили, для установки таких точек отладчик исполь- 
зует прерывание 03Н, которое удобно тем, что его вы- 
зов, в отличие от вызовов других прерываний, зани- 
мает всего один байт. Для установки точки останова 
отладчик заменяет код байта программы по указан- 
ному адресу (предварительно запомнив его) на код 
вызова прерывания 03Н, чем, конечно же, изменяет 
контрольную сумму программы. Это обстоятельство и 
использует метод подсчета и проверки контрольных 
сумм. 

Метод контроля времени выполнения некоторых 
участков программы также служит для определения, 
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работает ли ваша прог- 
рамма под отладчиком. 

Пользуясь этим методом, 
вы должны заранее про- 
считать по таймеру (на- 
пример, запустив его 2-й 
канал) время выполнения 
какого-либо участка прог- 
раммы, а затем в процес- 
се работы программы вы- 
числить его заново, срав- 
нивая с эталоном. Если 
программа работает под 
отладчиком, то очевидно, 
что время выполнения 
контролируемого участка 
будет значительно боль- 
шим, чем время его “чис- 
той" работы. Недостаток этого метода заключается в 
необходимости реализации некоего механизма, учиты- 
вающего разное быстродействие процессоров (если, 
конечно, вы собираетесь эксплуатировать свою прог- 
рамму на разных компьютерах). Поэтому данный ме- 
тод наиболее эффективен в сочетании с механизмом 
защиты от несанкционированного копирования, имею- 
щим привязку к аппаратным особенностям машины. 

Интересный способ изматывания хакера при анали- 
зе работы программы — использование так называе- 
мых “пустышек 11 . Это участки программы достаточно 
большого объема, производящие некоторые сложные и, 
на первый взгляд, значительные вычисления, но на са- 


мом деле не имеющие ни- 
какого (или очень малое) 
отношения к работе прог- 
раммы. Для имитации 
важности “пустышек" в 
них необходимо включать 
какие-либо фрагменты, 
которые могли бы заинте- 
ресовать хакера. Это мо- 
гут быть, например, вызо- 
вы таких “важных** пре- 
рываний, как 13Н, 21Н, 
25Н, 26 Н, перехват этих 
прерываний и т.п. 

Среди прочих способ )в 
защиты от отладчиков 
особенно оригинальными 
нам представляются прие- 
мы, использующие аппаратные особенности компьюте- 
ра (например, порты). Это и будет предметом даль- 
нейшей дискуссии на затронутую тему в одной из сле- 
дующих нашей статей. 

В заключение остается добавить, что все описанные 
выше приемы защиты прошли практическую апроба- 
цию и оформлены в виде специальных программ, 
исходные тексты и исполняемые модули которых были 
включены в электронный журнал “НСК“, выпуска- 
емый с февраля 1992 г. центром Совмаркет. 

А. Долгин, С. Расторгуев 



СНГ: $іш передает ЗРАКСстанцию 

Компания 5ші Місгозузіелз безвоз- 
мездно передала ЗРАКС-сервер бази- 
рующейся в Москве Ассоциации поль- 
зователей системы ІШХ. Компьютер 
будет использоваться как один из узлов 
системы электронной почты Кеісош. 

Тке Теіериііпі Ноіііпе, 
РеЬгиагу 24, 1991 

МІСКОСОМ добавляет дезинфектор 
для вируса МісЬеІалвеІо в ѴШх 2.0, 
Ггееѵѵаге-версию своей антивирусной 
программы Ѵігех. МсАГее и Зутапіес 
также предлагают специальную защиту 
от этого вируса, который затирает же- 
сткие диски 6 марта. 

ЗІІрКА выпустила два новых ком- 
пактных модема Ѵ.32 со скоростью до 
14 400 бит в секунду и возможностью 
передачи факсимильных сообщений. 

Отделение Сепегаі Моіога — Ни^Нез 
№1>ѵогк Зузіетз — продемонстриро- 
вало телефонные аппараты и базовые 
сотовые станции, которые могут обра- 
батывать и аналоговые и цифровые со- 
товые переговоры в соответствии со 
стандартами метода Множественного до- 
ступа с разделением времени (ТОМА). 
Сотовая индустрия ввела такие системы 


“двойного назначения", чтобы утроить 
пропускную способность американских 
сотовых сетей, и МсСа\ѵ, крупнейшая 
фирма-оператор, заявила, что установит 
такое оборудование. Сепегаі Моіоге на- 
деется, что телефоны ТОМА будут про- 
даваться как недорогое дополнение к 
автомашинам этой корпорации. Предла- 
гается также усовершенствованное 
ТОМА-оборудование под названием Еп- 
Ьапсеб-ТОМА. Утверждается, что его 
пропускная способность в 15 раз выше, 
чем у существующих систем. 

Тке Теіериііпц Ноіііпе, 
РеЬгиагу 24, 1991 

Фирмы “Консультации и Марке- 
тинг“, КиМ, (Москва) и АК115 Напсіеіз 
А.С. (Вена) совместно выпустили новый 
программный продукт под названием 
Ѵііазег, работающий в операционной 
среде системы М3 ООЗ (версии 3.30 и 
выше) на ІВМ-совместзегіеі. 


Справочная система на русском 
языке включает в себя полгіое описание 
синтаксиса команд и параметров языка 
РСЬ5, при этом учитываются особенно- 
сти их применения для различных 
принтеров. В частности, язык РСЬ5 по- 
зволяет следующее: использовать уже 
разработанные и создавать свои 
шрифты, изображать в различных мас- 
штабах растровую графику, создавать 
собственные изображения, накладывать 
изображения и текст друг на друга, за- 
крашивать изображение и текст различ- 
ными штриховками или оттенками се- 
рого цвета, управлять ориентацией 
страниц и расположением изображений 
и текста и т. д. 

Для установки пакета Ѵііазег необхо- 
дим жесткий диск, причем общий объем 
необходимых файлов составляет около 
1,6 Мбайт. Пакет поддерживает работу 
с Місгозоіі Моизе, однако он не оснащен 
собственными драйверами кириллицы 
клавиатуры и экрана. Применение па- 
кета Ѵііазег будет полезно для специ- 
алистов, разрабатывающих текстовые и 
графические редакторы, а также про- 
граммы, использующие широкие воз- 
можности лазерных принтеров. 

Телефон АКШ: (095)230-56-12 
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КОРОТКО ОБ АКСпеІ 



В этой небольшой статье мы 
рассмотрим некоторые принципы 
функционирования и аппаратные 
особенности построения локальных 
вычислительных сетей (ЛВС) типа 
АКСпеІ. 


Коротко 
об АКСпеІ 


" Немного , но многое “ 

Плиний-младший 

В настоящее время на рынке аппаратных средств 
ЛВС одним из наиболее распространенных стандартов 
является АКСпеІ (АиасЬесІ Кезоигсе Сотриіег пеі). Он 
был разработан американской фирмой Эаіароіпі еще в 
начале 70-х годов. Одной из основных отличительных 
особенностей АКСпеІ является метод доступа абонен- 
тов к сети — эстафетная передача Маркера (Юкеп 
ра55іп&). Стандарт АКСпеІ является, вообще говоря, 
более широким понятием, чем просто метод доступа, 
поскольку определяет также и другие важные харак- 
теристики ЛВС этого типа, такие, например, как па- 
раметры электрических сигналов, размеры передава- 
емых пакетов, способ контроля передаваемых данных 
и т.п. Сам же метод доступа — эстафетная передача 
Маркера — впоследствии был принят в качестве меж- 
дународного стандарта — ІЕЕЕ 802.4-85, хотя сам 
стандарт АКСпеІ в полной мере ему не соответствует. 
В ЛВС АКСпеІ могут использоваться две схемы соеди- 
нения абонентов сети, называемые топологиями, — 
топологии “распределенная звезда“ и “шина“. Это 
значит, что шина сети объединяет все рабочие стан- 
ции (персональные компьютеры), входящие в ЛВС, 
либо в форме серии звездообразных схем, либо просто 
параллельно друг другу. Указанный метод доступа 
предполагает, что от станции к станции последова- 
тельно под управлением сервера передается некий 
общий пакет данных, который в предельном случае 
(нет передачи информации) может состоять из одного 
только Маркера разрешения (Іокеп). Этот Маркер 


представляет собой последовательный набор служеб- 
ных бит, содержащий опознавательный знак конкрет- 
ной станции. Та станция, которой предназначен этот 
Маркер, имеет возможность передать собственный па- 
кет данных размером до 0,5 Кбайта, причем сами дан- 
ные в этом пакете могут занимать максимум 508 байт, 
а остальные байты используются под адрес стан- 
ции-приемника, адрес станции-передатчика и другую 
служебную информацию. Маркер перемещается по се- 
ти как по логическому кольцу — от станции к стан- 
ции. Поэтому понятно, что принцип работы такой се- 
ти не зависит от того, какую физическую конфигура- 
цию она имеет в действительности — “распределен- 
ная звезда“ или “шина“. Таким образом, каждая стан- 
ция как адресат ждет получения Маркера, и, когда это 
событие происходит, она может посылать в сеть свои 
собственные данные, если, конечно, это необходимо. 
По сути, передаваемые станцией данные присоединя- 
ются к общему передаваемому по сети пакету. В слу- 
чае же, если в получаемом пакете содержатся данные 
с адресом принимающей станции, то после успешного 
приема они просто удаляются из общего передаваемо- 
го пакета. Далее Маркер передается следующей по но- 
меру подсоединенной к сети станции. Если же после 
двух попыток передачи Маркера эта станция не отве- 
чает, Маркер с общим пакетом данных передается на 
следующие, возможно активные, станции сети. Таким 
образом, сеть не нарушается и в случае отключения от 
нее одной или нескольких станций. Контроль прини- 
маемых данных происходит по 16-разрядному 
СКС-коду. 
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Рис . 1 

Понятно, что для посылки полного сообщения стан- 
ции чаще всего недостаточно передачи лишь 508 байт 
информации, поэтому общее время пересылки данных 
от станции к станции определяется временем несколь- 
ких проходов маркера по сети, которое, вообще го- 
воря, не сложно определить. 

Каждая плата АКСпеі-контроллера станции имеет 
свой уникальный физический адрес в диапазоне от 0 
до 255, что позволяет посылать данные конкретному 
адресату (рабочей станции). Кстати, Маркер перехо- 
дит от станции к станции в порядке возрастания их 
адресов, причем абсолютно неважно, являются ли 
станции с последовательными адресами (номерами) 
соседними. Так, например, станции с адресами 1 и 2 
могут находиться на разных концах сети. Логическое 
кольцо передачи Маркера замыкается при его пере- 
даче от станции с наибольшим существующим номе- 
ром к станции с наименьшим существующим номе- 
ром. Конечно, если две станции имеют одинаковый 
физический адрес — ошибки при работе в такой сети 
неизбежны. Надо отметить, что наряду с возможно- 
стью посылать данные конкретному адресату, суще- 
ствует и возможность посылки сообщения “для всех“, 
а именно, сообщения типа Ьгоасісазі, которое прини- 
мают все активные станции, не удаляя его из общего 
пакета данных после чтения. Адрес принимающей 
стороны в таком сообщении устанавливается обычно 
равным нулю, и естественно, что этот нулевой адрес 
не должен использоваться на “реальных 44 подключа- 
емых к сети станциях. 

Метод эстафетной передачи Маркера в сетях типа 
АКСпеІ позволяет достигать достаточно высокой ско- 
рости передачи данных — около 2,5 Мбит/с. Конечно, 
эта скорость существенно ниже, чем, скажем, при 
использовании метода доступа ЕіНегпеі (С8МА/СО), 
однако не следует забывать, что и стоимость плат 
контроллеров для ЕіНегпеі в несколько раз выше. 

Вообще говоря, от физической топологии ЛВС типа 
АКСпеІ зависит реализация плат контроллеров стан- 
ций. При соединении же типа “распределенная 
звезда 44 для подключения станций необходимо также 


специальное дополнительное оборудова- 
ние — концентраторы сигналов, так назы- 
ваемые НІІВ, выполняющие обычно функ- 
ции распределителей или усилителей сиг- 
налов. Как правило, НУВ выглядит как не- 
большая металлическая коробочка. Причем 
при выборе НИВ следует иметь в виду как 
количество подключаемых к нему рабочих 
станций (4, 8, 16 и т.д.), так и максималь- 
но допустимое расстояние между ним и 
станцией. Понятно, если необходимо соеди- 
нить только две станции (вообще говоря, 
несколько тривиальная задача), то для это- 
го никакой НИВ не нужен, поскольку такое 
соединение можно выполнить при помощи 
обыкновенного коаксиального кабеля, ну и 
при наличии сетевых контроллеров, разу- 
меется. Обычно расстояние между этими 
станциями не должно превышать 600 м. В противном 
случае без специального усилителя сигналов не обой- 
тись. Заметим, что І-ШВ подразделяются на активные 
и пассивные. Если пассивный НИВ, по сути, выполня- 
ет задачу распределения сигналов (без их усиления), 
то активный НИВ ретранслирует (усиливает) переда- 
ваемые сигналы, для чего ему, безусловно, необходим 
источник электропитания. Активные НИВ на неболь- 
шое количество каналов (например, три-четыре) иног- 
да могут быть выполнены в виде платы, вставляемой 
непосредственно в слот расширения на системной пла- 
те компьютера, выполняющего роль сервера. Понятно, 
что в этом случае НИВ получает энергию от блока пи- 
тания компьютера. Восьмиканальные НИВ обычно вы- 
полнены в виде отдельного устройства с собственным 
встроенным блоком питания. Активные НИВ обеспе- 
чивают надежную работу на расстояниях порядка 
600 метров, в то время как пассивные, как прави- 
ло, — не более 30 метров. Так как при использовании 
пассивного НИВ сигнал, конечно, ослабляется, то не 
рекомендуется соединять последовательно только пас- 
сивные НИВ. Для расширения сети обычно использу- 
ют комбинации включения активных и пассивных 
НИВ. На рис. 1 приведен пример схемы ЛВС АКСпеІ, 
использующей топологию типа “распределенная звез- 
да 44 . 

В том случае, когда 
для сети АКСпеІ приме- 
няется топология типа 
“шина 44 , отдельные стан- 
ции соединяются друг за 
другом через один общий 
коаксиальный кабель со 
стандартными Т-образ- 
ными ВЫС-соединителя- 
ми. На обоих концах об- 
разуемой “шины 44 всегда 
подключаются специаль- 
ные резисторы (номи- 
нальное сопротивление 
93 Ома), так называемые 



Терминатор 




Рис . 2 
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терминаторы, согласующие волновое сопротивление 
кабеля. Обычно при использовании такой тополо/ии в 
ЛВС АКСпеІ объединяются не более восьми станций. 
Пример ЛВС с топологией типа “шина“ приведен на 
рис. 2. 

Как правило, платы контроллеров для топологии 
типа “шина 44 несколько дороже, чем платы контролле- 
ров для топологии типа “звезда 44 , хотя, с другой сто- 
роны, в первом случае нет нужды использовать допол- 
нительное оборудование для подсоединения стан- 
ций — НІІВ. Физическое соединение станций ЛВС 
между собой, независимо от топологии, может выпол- 
няться не только 93-омным коаксиальным кабелем, но 
и витой парой проводников или оптоволоконным кабе- 
лем. Использование витой пары существенно дешевле, 
чем применение коаксиального кабеля, но помехоза- 
щищеность в этом случае гораздо хуже. Поэтому ви- 
тые пары проводников выгодно применять только при 
небольших расстояниях между станциями. Обратная 
ситуация наблюдается при использовании оптоволо- 
конного кабеля, поскольку такой кабель является 
практически идеальной средой для передачи сигналов 
на большие расстояния, хотя и понятно, что цена его 
существенно выше. 

Плата АКСпеІ-контроллера для ІВМ-совместимых 
компьютеров, как правило, имеет половинную ширину 
(соответственно 8 разрядов данных), что дает возмож- 
ность использовать ее, например, в лэптопах. При- 
мерная структурная схема платы АКСпеІ-контроллера 
приведена на рис. 3. 

“Сердцем 44 этой платы является микросхема 
І_АЫ-контроллера (Ьосаі Агеа Ые^ѵогк, ЬАЮ, пред- 
ставляющая собой, вообще говоря, специализирован- 
ный микропроцессор, тактовая частота работы кото- 
рого задается кварцевым генератором. Часто эта мик- 
росхема выполнена в корпусе типа РЬСС ( Ріазііс Ьеа- 
дед СНір Саггіег); это квадратный пластмассовый кор- 
пус с контактными выводами в виде латинских букв I, 
расположенными по его периметру. Микросхема в та- 
ком корпусе должна вставляться в специальную поса- 
дочную РЬСС-панель. Кроме того, на плате 
АКСпеі-контроллера находятся две-три ТТЛ-микро- 
схемы, ОЗУ, ППЗУ для автозагрузки, ОІР-переключа- 



Рис . 3 



Рис . 4 

тели, перемычки и формирователь сигнала, связываю- 
щий микросхемы ІАЫ-контроллера с кабелем сети. 
Размер ОЗУ обычно составляет не менее 2 Кбайт, что 
позволяет сохранять до 4 пакетов данных максималь- 
ной длины (508 байт), предназначенных для данной 
станции. ППЗУ управляется от микросхемы ІАЫ-кон- 
троллера и является, вообще говоря, необязательным 
элементом на плате, так как записанные в нем коды 
предназначены для выполнения процесса загрузки и 
для подключения к сети, если на рабочей станции от- 
сутствуют дисковые приводы. При помощи ОІР-пере- 
ключателей выбираются, во-первых, адрес станции в 
диапазоне 0 - 255 и, во-вторых, базовые адреса ОЗУ 
и ввода-вывода. Следует отметить, что адреса ОЗУ на 
плате АЯСпеІ-контроллера лежат в области адресного 
пространства компьютера (рабочей станции). Поэтому 
при установке соответствующего адреса это следует 
иметь в виду. Типовой базовый адрес ОЗУ обычно — 
ОООООН, а для ввода-вывода — 2Е0Н. При помощи 
перемычек на плате выбирается один из номеров пре- 
рывания (чаще всего это — ІК(?3, ІК(?4, 1К(}5 или 
ІК(}7), свободных на данном компьютере. ТТЛ-микро- 
схемы, расположенные на плате, выполняют функции 
промежуточного хранения адресов и данных. 

Формирователь сигнала между ІАЫ -контроллером и 
сетевым кабелем, подключаемым к ВЫС-соединигелю 
на плате, выполнен в современных АКС- 
пеі-контроллерах как гибридная микросхема. Пример- 
ная структурная схема такого формирователя приве- 
дена на рис. 4. Гальваническое разделение сигналов в 
сети и логических сигналов на плате обеспечивает 
импульсный трансформатор. Пороговый детектор в 
свою очередь преобразует получаемые уровни сигналов 
к ТТЛ-уровню. 

Фирмы — изготовители сетевого оборудования по 
стандарту АКСпеІ вместе с контроллерами, НІІВ, и 
кабелями предлагают соответствующее программное 
обеспечение, поддерживающее эти аппаратные сред- 
ства. 

А Борзенко 
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Короткая история 
маленькой мышки 


“Жила-была мышка Мауси... а 

К. Чуковский 

Первая мышка была из дерева. В 1963 году в Стэн- 
фордском исследовательском центре ее разработал 
Д. Энжелбарт. Внутри этой “первобытной 44 мышки 
находились два колесика, на которых она и каталась. 
Колесики в свою очередь были связаны с осями пере- 
менных резисторов, изменение сопротивления которых 
при вращении было пропорционально перемещению. 
По сути, первая мышка была простым аналоговым 
устройством ввода, чем-то смахивавшим на джойстик. 
Но в 60-е годы мышка Энжелбарта оставалась еще 
экзотикой. Только в начале 70-х годов фирма Хегох 
проявила инициативу и взялась за разработку цифро- 
вой мышки. Заказ на эту разработку получил 
Дж. Хали (Надѵіеу), работавший в исследовательском 
центре Пало-Альто. И хотя компьютеров АЬТО, для 
которых и предназначалась первая цифровая мышка, 
было выпущено всего около сотни штук, начало было 
положено. 

В 1975 году, снова по заказу фирмы Хегох, Хали по 
сути дела разработал некий стандарт на цифровые 
мышки, который впоследствии был адаптирован и 
использовался многими изготовителями до начала 
80-х годов. А Хали основал в Беркли собственную 
фирму по разработке и изготовлению цифровых мы- 
шек. 

Мышка “от Хегох“ как устройство ввода заинтере- 
совала многих крупнейших производителей програм- 
много обеспечения. Однако первая РС-Моизе (Сепіиз) 
увидела свет только в 1982 году. Эта “гениальная 44 
мышка имела в то время серьезный недостаток — не 
было программного продукта, который позволял бы ее 
эффективно использовать. 


Несколько иная история связана с МісгозоН Моизе. 
Фирма МісгозоН — этот крупнейший производитель 
программного обеспечения — пыталась создать соб- 
ственный аппаратный продукт для того, чтобы гармо- 
нично завершить палитру своих, уже достаточно по- 
пулярных программных продуктов. Выбор пал на 
мышь. Как устройство ввода мышка МісгозоП должна 
была обеспечить поддержку программе обработки тек- 
стов — >Уогсі. Первая мышка МісгозоН моделировалась 
конструкторами из глины — устройство должно было 
быть не только легко в работе, но и удобно 
размещаться в руке. Собственно, подобные требования 
остаются доминирующими и сегодня. 

Однако не только в США конструкторы были озабо- 
чены созданием мышек. Около 10 лет назад в Швей- 
царии была основана фирма Ьо&іІесН. Первоначально 
она планировалась как фирма, оказывающая консуль- 
тационные услуги по программному обеспечению. Но 
изменив основной профиль деятельности, фирма бы- 
стро добилась больших успехов на европейском рынке 
как производитель устройств ввода — мышек. Такие 
известные производители компьютеров, как Арріе, 
Оііѵеиі, \Ѵап§, приобретали мышек у Ьо^ПесН, кото- 
рых уже впоследствии предлагали конечному потреби- 
телю в составе собственного оборудования. 

Интересно, что первоначально представители япон- 
ской электронной промышленности пессимистически 
отнеслись к возможности создания мышек на должном 
техническом уровне. Ведущие сотрудники МісгозоН 
специально встречались с японскими специалистами 
(в области создания электронных устройств), чтобы 
обсудить эту проблему. В то время, когда мышки Ьо§- 
ЙесН изготовлялись для других компаний, фирма Мі- 
сгозой в 1983 году представила свою собственную раз- 
работку — Виз Моизе для ІВМ РС. Это была мехам и- 
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ческая мышка, основой которой являлся стальной шар 
с двумя связанными с ним роликами. Для управления 
мышкой на ее корпусе размещались две клавиши 
(зеленого цвета). Связь “зеленоглазой" мышки Мі- 
сгозоН с компьютером осуществлялась через специаль- 
ную интерфейсную плату, базирующуюся на микрос- 
хеме параллельного интерфейса фирмы Іпіеі — І8255. 
Только годом позже появились первые мышки, для ко- 
торых не требовалась специальная интерфейсная 
плата, — свое победное шествие начали мышки, под- 
ключаемые через последовательный интерфейс 
К8-232С. Кроме этого, фирма МісгозоН позаботилась 
о том, чтобы программный драйвер для мышки мог бы 
свободно устанавливаться в М8-008. 

Примерно в это же время фирма Ьо^ИесН начала 
продавать производимые ею мышки уже под собствен- 
ной маркой. Несомненным преимуществом мышек 


Ьо^ЙесН была их относительно низкая цена при доста- 
точно высоком качестве исполнения. Впрочем, на аме- 
риканском рынке по-прежнему господствовала Мі- 
сгозой Моизе. 

Конечно, история компьютерной мышки тесно 
связана с развитием графических средств на компью- 
терах. Своей популярностью среди пользователей пер- 
сональных компьютеров" мышка во многом обязана 
компьютерам фирмы Арріе, для которых она, безу- 
словно, была неотъемлемым атрибутом. Широкий про- 
рыв мышек на рынок ІВМ-совместимых персональных 
компьютеров связывают обычно с программным про- 
дуктом фирмы МісгозоН — ^іпсІоѵѵз. 

Несмотря на то, что производством компьютерных 
мышек занялись даже такие признанные лидеры, как 
Хегох и ІВМ, фирма Ьо&ііесН сохранила свою добрую 
репутацию. Именно сотрудникам Ьо^іІесН пришла 
оригинальная мысль — “перевернуть" мышку. Так ро- 
дился трекбол (ІгаскЬаН). Принцип действия трекбола 
аналогичен мыши. Но поскольку у трекбола приво- 
дится в движение не сам корпус устройства, а только 
шар, то основным его преимуществом является 
повышение точности управления курсором. Первая ра- 
диомышка (беспроводная связь с компьютером в ради- 
одиапазоне), кстати, также является разработкой Ьо&- 
НесЬ. 

Скоро мышке исполнится 30 лет. Многие современ- 
ные программные продукты, такие как САЭ/САМ, 
издательские системы, сегодня просто трудно себе 
представить без мышки или ее младших братьев 
(ІгаскЬаН, иптоизе). Развитие компьютерной мышки 
продолжается — появляются новые модели, улучша- 
ются технические характеристики: чувствительность, 
разрешающая способность. Но неизменно элегантным 
и эргономичным остается ее дизайн. 

А. Борзенко 



ТОЛЬКО ЛУЧШЕЕ 

Крупнейший производитель персональных компьютеров в стране — фшэма Аквариус 
Системз Интеграл, известная качеством своей продукции, продает за рубли компьютеры 
любой конфигурации от самого популярного А8І 286 и универсальных А8І 386/ 8Х, 
А8І 386/33 до суперкомпьютера А8І 486 и периферию к ним: 


Матричные принтеры МісгоІіпе-193 Окісіаіа, 9 игл 
Лазерные принтеры Неміеп-Раскагсі 
Мониторы ѴСА, 14 дюймов 
Мышь 8ерот Моідзе, 3-клавишная 
Дискеты: 5.25“/1.2 Мбайта, 3.5“/1.44 Мбайта 
Интерфейсные кабели для принтера 

а также 

Интегратор “ВИКТОРИЯ 1 * — оболочка 00$ нового класса, 
так и для профессиональных программистов. 


Винчестеры \Ѵе$іегп Оі^ііаі 40 Мбайт 
Дисководы 3.5“/1.44 Мбайта, 5.25“/360 Кбайт, 

5. 25 “/1.2 Мбайта 

Клавиатуры 101 Ьаі/Сіг 8К-880113 811ЛТЕС 
Лицензионно-чистое программное обеспечение фирм 
Капшскеі, Ьошь, І\ т оѵе11, Эі§іш1 КезеагсЬ 


превосходный инструмент как для начинающих пользователей. 


Пишите по адресу: 127591 Москва, 
у л. Дубнинская 83, и Вы всегда 
получите исчерпывающую инфор- 
мацию о лучших советских 
компьютерах А8І. 

Звоните по телефону: 

(095)485-24-73 
Шлите факс по номеру: (095 )484-97-28 


Л 


а иагі ид 5Ѵ8ТЕМ8 імкоклі 


лйгк 


Приезжайте и приходите. Вы всегда будете желанными гостями. 
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Аббревиатура 5>1Ш расшифровывается как $1ап?огс1 
ІІпіѵегзИу Ыеілѵаге. Связано это с тем, что создатель 
первой рабочей станции $1Ж Ап<іу ВесМоІзНеіт был 
студентом этого университета. Девиз фирмы 81Ж — 
Ыеілѵогк Із Сошриіег (сеть есть компьютер). В отличие 
от персональных компьютеров рабочие станции 81Ж 
изначально приспособлены для работы в сети под опе- 
рационной системой ІІЫІХ. Файловая система станций 
51Ж носит название ЫР5 (сетевая файловая система). 
Фирма ЗІЖ тесно сотрудничает с официальным вла- 
дельцем операционной системы ІЖІХ — фирмой 
АТ&Т, что гарантирует стандартность операционной 
системы, используемой на компьютерах 51ІЫ, и за- 
щищает разработчиков и пользователей от неожидан- 
ностей, связанных с несовместимостью аппаратных и 
программных продуктов. Вот почему очень многие 
фирмы по производству аппаратуры и программных 
средств кинулись на рынок, наводняя его все новыми 
и новыми высококачественными продуктами для $ІІЫ. 
Если ІВМ РС-совместимые машины разделяют веду- 
щее место на рынке с машинами Арріе в классе пер- 
сональных машин, то в случаях, требующих мощности 
рабочих станций ЗрагсЗіаііоп, операционной системы 
Ь Т ЫІХ и прозрачной сети на основе ЫР5, используется 


Наверняка многим из вас доводилось 
встречать название фирмы 51ІМ. 

Либо в приложении к миниЭВМ, 
либо в разговорах об операционной 
системе ІІЫІХ, либо в описаниях самых 
современных рабочих станций. Сегодня 
мы немного расскажем о фирме 511 N 
и о ее идеологии. 


Что такое 


техника, ориентированная на ЗІЖ. Даже фирмы, 
использующие мощные машины фирмы ЭЕС, вклю- 
чают свои “Ваксы“ в сеть ЗІШ и переводят часть ра- 
бот на рабочие станции ЗрагсЗіаІіоп. 

Персональные компьютеры класса ІВМ РС хлынули 
в нашу страну в связи с насыщенностью западных 
рынков и в результате официальной политики, прово- 
димой с обеих сторон: с нашей — ориентация Акаде- 
мии наук на ІВМ, с их — запреты КОКОМ на вывоз к 
нам передовых технологий. При этом ЗІЖ-совмести- 
мые компьютеры оказались забытыми, несмотря на 
ряд преимуществ по сравнению с персоналками. 

Что такое ІЖІХ 

Разработанная ВеІІ ЬаЬогаіогіез АТ&Т в 60-х годах, 
операционная система ІІЫІХ была предназначена для 
обслуживания исследовательских коммуникаций. 
Исследователи работали вместе над общим проектом, 
при этом появлялась необходимость разделять инфор- 
мацию и разрабатывать прикладные системы для вы- 
полнения специализированных функций быстро и 
просто. 
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До 80-х годов система ІЖІХ использовалась в 
основном в университетах и правительственных иссле- 
довательских центрах. Построенная на основе набора 
простых, но мощных инструментальных средств, си- 
стема ІЖІХ вскоре стала применяться для разработки 
программных средств и легко перешла в промышлен- 
ные приложения. 

Так как фирма АТ&Т либерально относилась к ли- 
цензиям на ІЖІХ, в начале 70-х годов начали появ- 
ляться различные версии системы. Университеты, так 
же как и другие пользователи, получали лицензии на 
использование системы и адаптировали ее примени- 
тельно к своим нуждам. Появление первой коммерчес- 
кой реализации системы пришлось на середину 70-х, 
сразу вскоре после объявления продукта Хепіх — опе- 
рационной системы ІЖІХ фирмы МісгозоН. 

В 1981 году университет Вегсіеу в Калифорнии 
объявил о реализации операционной системы ІЖІХ, 
названной Вегсіеу ЗоНлѵаге ОізігіЬиІіоп (ВЗО), которая 
стала стандартом на машинах семейства ѴАХ фирмы 
ЭЕС (Оі^ИаІ Едиіршепі Согрога- 
Ііоп). Из В50 развилось много 
других версий операционной си- 
стемы ІЖІХ. 

В начале 80-х система ІЖІХ 
работала на большом числе раз- 
личных аппаратных платформ 
разных производителей в ши- 
роком диапазоне конфигураций. 

В 1984 году фирма АТ&Т на- 
чала лицензировать ІЖІХ 
Зузіегп V как коммерческий про- 
дукт. 



Что такое 
КІ5С и 5РАКС 

Сегодняшние рабочие станции 
51Ж используют процессоры, называемые КІ5С- 
процессорами. КІ5С — это сокращение от Кегіизеб 
Іпзігисііоп 5е1 Сошриііпе, т.е. процессор с 

уменьшенным числом инструкций, базирующийся на 
концепции 20/80. Было доказано, что 80% 

инструкций из полного набора используются в 20% 
случаев, а оставшиеся 20% — в 80% случаев. Для 
повышения производительности машин последние 

20% инструкций реализуются при помощи програм- 
мной логики, оставшиеся 80% — традиционным мик- 
ропрограммным способом. 

Так родилась архитектура 5РАКС. ЗРАКС расшиф- 
ровывается как Шкалируемая Архитектура Процес- 
сора. Наиболее ответственные операции выполняются 
высокоскоростными, но дорогими чипами на основе 
арсенида галлия, менее ответственные — эмиттерно- 
связанной логикой, далее — ТТЛ с барьером Шоттки 
и так далее. Таким образом достигается баланс между 
высокой производительностью и низкой ценой. Второй 
признак шкалируемости — возможность увеличения 


мощности систем путем дополнения существующей 
системы различными расширениями или замены одной 
ее части другой, совместимой, но имеющей лучшие 
характеристики. 

Одно из главных отличий рабочих станций 51Ж от 
мощных машин, совместимых с ІВМ РС, — отсутствие 
общей для памяти и периферийных устройств 
системной шины, замедляющей работу персонального 
компьютера, какой бы мощный процессор в нем ни 
использовался. Второе отличие — отсутствие зарезер- 
вированного под экранную область и базовую систему 
ввода/вывода участка памяти от 640 килобайт до 
одного мегабайта, третье немаловажное отличие — 
это изначальная ориентация 51Ж ХѴогкЗіаііоп на ра- 
боту в сети под операционной системой ІЖІХ. 

51ІИ лидирует 
в области рабочих станций 

Сегодня в компьютерной ин- 
дустрии преобладает тенденция к 
открытости, к возможности свя- 
зывать вместе стандартную аппа- 
ратуру и программные продукты 
различных производителей. С мо- 
мента своего основания 51Ж 
Місгозузіетз производит рабочие 
станции и серверы, базирую- 
щиеся на философии Ореп 
Сотриііпв. С наступлением эры 
Ореп Сотриііпв информация сво- 
бодно переливается между ком- 
пьютерными системами различ- 
ных производителей. Пользы пот- 
ребителям много: защита инвес- 
тиций в аппаратуру, программ- 
ные продукты, проекты, наличие 
широкого выбора дешевых высо- 
кокачественных программных продуктов, а также воз- 
можность использования лучших компьютерных сис- 
тем. С системами 511 N пользователь свободен в выборе 
решений, удовлетворяющих запросы, без ориентации 
на узкие места аппаратуры, операционных систем и 
сетевых архитектур. 

ЗипОЗ: краеугольный камень 
открытого компьютинга 

Открытый компьютинг базируется на операционной 
системе ІЖІХ. Наиболее существенная особенность 
ІЖІХ'а — переносимость. ІЖІХ работает на более 
разнообразных компьютерах, чем любая другая опера- 
ционная система, и используется тысячами разработ- 
чиков программных продуктов. 81Ж предоставляет 
мощную реализацию операционной системы ІЖІХ в 
многозадачной операционной системе ЗипОЗ. $1Ж 
поддерживает только одну операционную систему, так 
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что все ресурсы и технологические новшества направ- 
лены на то, чтобы сделать ЗипОЗ гибче, переносимее 
и проще в использовании. 

ЗипОЗ включает также поддержку интуитивного, 
базирующегося на иконках, графического пользова- 
тельского интерфейса ОРЕЫ ШОК. Стандартная 
оконная система, Х11/Ые>ѴЗ, и популярный Х-ин- 
струмент ХѴіе\ѵ предоставляют высокую оконную 
функциональность. Разработанная фирмой 51Ш сете- 
вая файловая система ЫРЗ (ЫеІ\Ѵогк РіІеЗузіеш) стала 
промышленным стандартом для доступа к файлам в 
сети, кроме того, она дает возможность мощного мно- 
гопользовательского сетевого применения. В насто- 
ящее время разработано множество устройств и про- 
грамм для включения в сеть ЗІІЫ различных ком- 
пьютеров — от персоналок до суперкомпьютеров. 

Эти стандарты увеличивают продуктивность труда 
пользователей — через ЗРАКС и другие стандартные 
микропроцессорные системы — и помогают разработ- 
чикам расширить возможности 
своих продуктов. 

ЗипОЗ — это система ІЖІХ с 
более чем 300000 пользователей 
во всем мире и величайшим на- 
бором КІЗС/ШІХ продуктов, 
включающим свыше 3000 гото- 
вых программ так называемого 
ЗРАКСХѴаге. Высокое качество 
плюс технология ЗіаІе-оМЬеагі, 
включая гибкие сетевое и окон- 
ное окружения, делают ЗипОЗ 
ведущей ІІЫІХ-платформой на 
современном рынке. 

Средства управления 
файлами и памятью 

ЗипОЗ включает интегрирован- 
ные системы управления файла- 
ми и памятью, которые эффективно управляют сис- 
темными ресурсами и системным интерфейсом, позво- 
ляя программам работать лучше за счет метода адрес- 
ных карт. ЗипОЗ создает системную виртуальную па- 
мять для хранения ресурсов, доступных системе, 
включая файловую систему как на локальных устройс- 
твах памяти, так и на тех, которые доступны через 
сетевой протокол типа ОЫС/ЫРЗ. Система использует 
такие методы, как подкачка памяти и плавающие 
процессы для адаптации и увеличения рабочей обла- 
сти запрошенной памяти. 

Динамическая компоновка 
и распределенные библиотеки 
используют ресурсы эффективно 

При динамической линковке программы состоят из 
изолированных деталей, реализованных в виде функ- 


ций. Программы динамически связываются с систем- 
ным сервисом и библиотечными модулями, обеспечи- 
вая легкую приводимость их к приложениям, разрабо- 
танным 51Ж, сторонним разработчикам и пользовате- 
лям. 311Ы поддерживает несколько библиотек в дина- 
мически линкуемой форме, включая 5ѴШ и ВЗО-со- 
вместимые версии как библиотек С, так и других, свя- 
зывающих систему с приложениями. Оконная система 
также поставляется в форме распределенной библио- 
теки, позволяя приложениям использовать общий код. 
По сравнению с традиционными архивными формами 
системных библиотек ЗипОЗ более эффективно ис- 
пользует системную память и дисковые ресурсы, 
оставляя больше свободной памяти для приложений. 

Системные 

административные расширения 

ЗипОЗ включает различные 
административные расширения 
для оптимизации локальных и 
удаленных системных операций: 
например, утилита 51Ж Іпзіаіі 
уменьшает время установки поль- 
зовательской системы, включая 
инсталляцию многопользователь- 
ских клиент-сервер конфигура- 
ций. Благодаря быстрой инстал- 
ляции пользователь получает воз- 
можность быстрой установки сис- 
темы в стандартной конфигура- 
ции. Управление процессом осу- 
ществляется с помощью системы 
меню. ЫЕТсІізк поддерживает ра- 
боту бездисковых клиентов и поз- 
воляет добавлять в сети новых 
клиентов без разрушения сущест- 
вующих. Аиіошоипіег автомати- 
чески монтирует удаленные фай- 
ловые системы и предоставляет прозрачный доступ к 
файловым системам базы всей сети. Включение в сис- 
тему утилиты форматирования диска расширяет 11р- 
Тіте (системное время работоспособности) и умень- 
шает время форматирования диска. Сетевая Информа- 
ционная служба (ЫеЬѵогк Іпіогтаііоп Зегѵісе) упроща- 
ет управление, обеспечивая доступ к централизован- 
ной базе административных данных. 

Сетевые возможности 
обеспечивают 

прозрачную коммуникацию 

Философия открытых систем (Ореп ЫеЬѵогк Сош- 
риііп^) благоприятствует более широкому выбору ре- 
шений сетевой среды по сравнению с другими сете- 
выми философиями. Среда Ореп\Ѵіпс1о>ѵ5 создает 
общую платформу для сетевых оконных приложений. 
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Утилита ІЖІХ Ю ІЖІХ сору (ІШСР) Нопеу ОапВег 
информирует системных администраторов о состоянии 
коммуникаций между ІЖІХ-системами, обеспечивает 
их переносимость и секретность. Семейство сетевых 
продуктов ЗипЫеІ дает пользователям возможность 
включиться в сетевую среду 81Ж. 

Промышленные стандарты 
для защиты инвестиции 

Чтобы дать возможность как пользователям, так и 
разработчикам предвидеть будущие технологии и за- 
щитить инвестиции, ЗІЖ предлагает и поддерживает 
мировые промышленные стандарты. Эти стандарты 
включают: РОЗІХ 1003.1-1988 ІЕЕЕ (ІпзШиІе о? Еіес- 
ігісаі апсІ Еіесігопісз Еп^іпеегз), ЕІРЗ 151- 1 (Ресіегаі 
ІпГогтаііоп Ргосеззіп^ Зіапсіагсі), ХРС2 и ХРСЗ 
(Х/Ореп РогІаЬіШу Сиісіе), АТ&Т Зузіет V Іпіегіасе 
ЭеПпШоп (5ѴЮ2 и часть из 5ѴЮЗ), 5СЭ 1.0 (ЗРАКС 
Сотрііапсе ЭеПпіІіоп), Интерна- 
циональные стандарты, такие как 
наборы национальных фонтов и 
раскладки клавиатуры. 

Переменно- 
дооавляемые 
возможности 

ЗІЖ развивает ядро в соответ- 
ствии со стандартными систем- 
ными интерфейсами. Подгружае- 
мые модули позволяют разработ- 
чикам создавать продукты, кото- 
рые могут быть легко добавлены 
в систему. ЗипОЗ также дает воз- 
можность открывать до 255 фай- 
лов на процесс для создания 
больших комплексных приложений и до 256 псевдо- 
терминалов для увеличения числа оконных и удален- 
ных вхождений в систему. Возможности асинхронного 
ввода/вывода значительно увеличивают производи- 
тельность в приложениях, критичных ко времени вы- 
полнения, и в базах данных. Другая часть окружения 
ЗипОЗ — РС РіІеЗузІетп, позволяет пользователям чи- 
тать и записывать гибкие диски в формате МЗ-ООЗ. 

$ѴК4 — унифицированный ІЖІХ 

Система ІЖІХ 8ѴК4 фирмы АТ&Т продолжает са- 
новские традиции открытого компьютинга. 8ѴР4 — 


это результат эволюции, соглашений и достижений в 
индустрии ІЖІХ. ЗѴК4 согласуется с большинством 
существующих индустриальных стандартов и включает 
важнейшие возможности каждой из распространенных 
версий ІЖІХ: ЗѴКЗ, ВЗЭ 4. 2/4.3, 8ипОЗ и Хепіх. 
Фирма 81Ж полностью взяла на себя обязанности по 
разработке высококачественных аппаратных и про- 
граммных платформ для работы 8ипОЗ/8ѴК.4. И, в 
отличие от большинства разработчиков, 81Ж уже се- 
годня предлагает тестовую платформу, которая допус- 
кает простой переход на 8ѴК4. Пользователи 81Ж, 
работающие с ЗипОЗ, смогут легко переходить на бу- 
дущие стандарты ІЖІХ с 5ѴК.4. Используя интерфейс 
бинарной совместимости (АВІ), можно писать про- 
граммы для работы на различных однопроцессорных 
платформах. Приверженность Зип05/8ѴК4 ЗСЭ 
(Определения ЗРАКС-Совместимости) позволяет раз- 
работчикам создавать программы, работающие без 
изменений на всех системах 5РАЯС — от лэптопов до 
суперкомпьютеров. 81Ж предлагает инструментарий, 
необходимый для переноса про- 
дуктов с распространенной в нас- 
тоящее время системы ЗипОЗ 4.1 
в 5ѴК.4. К тому же 811 N допуска- 
ет разработку продуктов, функ- 
ционирующих в основном 
режиме, и позволяет разработчи- 
кам проверить, как их 
программы будут выполняться че- 
рез интерфейс бинарной совмес- 
тимости. 81Ж тесно сотрудничает 
с партнерами, чтобы гаранти- 
ровать, что ЗѴК4 дает пользова- 
телям наилучшую среду для про- 
дуктивной работы любых прило- 
жений. 

Компьютерная индустрия ра- 
нее была завалена разношерстны- 
ми продуктами. Сегодня пользователи, которые хотят 
иметь свободный выбор среди лучших мировых про- 
дуктов, идут к открытому компьютингу. Фирма 51Ж 
была среди тех, кто начинал активно разрабатывать 
это направление. Она рассчитывает и впредь объеди- 
нять это движение. С установленной базой из более 
чем 300000 высокопроизводительных рабочих станций 
и серверов и с более чем 3000 программных продуктов 
Зрагс\Ѵаге, доступных под ЗипОЗ, 51Ж действительно 
устанавливает стандарты для открытого компьютинга 
ІЖІХ — сегодня и завтра. 

По материалам фирмы 
8ТЖ Місгозузіетз 
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П реимущества СУБД Вігіеѵе известны. 
Они неоднократно обсуждались 
в литературе, в том числе и авторами 
настоящей статьи (см. “Компьютер- 
Пресс“ № 8' 91 ). Сегодня мы рассмотрим 
дополнительные средства, 
предоставляемые для решения проблемы 
обработки данных в среде А Ьѵеіі 
Ыеі\Ѵаге. 

Пакеты 

ХИеѵе, 

ХСЫ и $са 


Как известно, Ыоѵеіі разрабатывает и поставляет 
наиболее распространенную сетевую операционную 
систему (ОС) Ыоѵеіі Ыеі\Ѵаге. Метод доступа Вігіеѵе 
(который громко называется фирмой СУБД Вігіеѵе) 
поставляется фирмой вместе с операционной системой 
и в настоящее время фактически является стандартом 
доступа к информации в локальных вычислительных 
сетях (ЛВС). Чтобы облегчить работу пользователя с 
Вігіеѵе, фирма Ыоѵеіі разработала дополнительные 
продукты, к числу которых относятся: 

Моѵеіі №і\Ѵаге Хігіеѵе 

Пакет создания и манипулирования базой данных. 

ІЧоѵеІІ №і\Ѵаге 8<}Ь 

5К}Б-сервер. 

Моѵеіі №(\Ѵаге Х(}Ь 

Пользовательский ЗрБ-интерфейс. 

Прежде чем перейти к описанию Хігіеѵе, 5(}Ь и 
Х(2Ц остановимся кратко на основных возможностях 
Вігіеѵе. 

Вігіеѵе поддерживает реляционную модель данных и 
характеризуется следующими функциональными воз- 
можностями: 

■ наличием языка описания данных, реализованного в 
виде параметров утилиты создания отношений; 

■ защитой от несанкционированного доступа (НСД) 
путем задания пароля, а также шифрования данных 
на диске; 

■ наличием языка манипулирования данными в виде 
набора функций (библиотек), вызываемых из языков 
программирования Си, Паскаль, КОБОЛ и Бейсик 


фирм Місгозоіі, Баііісе и Вогіапсі. Этот язык позво- 
ляет осуществлять поиск записей по адресу (ука- 
зателю) или ключу; выдачу записей в последова- 
тельности, определяемой физическими адресами 
хранения информации; построение гистограмм; 
получение значений текущего, следующего и преды- 
дущего указателя на отношение. Возможны также 
операции ввода, удаления, изменения записей, осво- 
бождение занимаемых ресурсов, блокирования запи- 
сей и отношений; 

■ наличием развитых средств физической организации 
данных, описываемых ниже. 

Прежде всего следует отметить, что индексы 
(сбалансированное В-дерево) и данные хранятся в 
одном файле. Поэтому при создании файла данных 
требуется задать хотя бы один ключ. 

Далее, есть возможность создавать множество базы 
данных на двух логических дисках, менять размеры 
блоков и записей, предварительно занимать необхо- 
димое дисковое пространство, динамически расши- 
рять занимаемое пространство, использовать вторич- 
но “дырки* 4 , влиять на размеры буферов, задавать 
любую последовательность сортировки. 

Наконец, обеспечивается компактность индексных 
блоков. Если в блоке индексов освобождается место, 
то запись перемещается на него, а не в новые блоки. 
В языке описания имеются средства сжатия инфор- 
мации (хвостовых пробелов). В новых версиях 
Вігіеѵе предусмотрено, кроме того, и дополнительное 
сжатие информации; 
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■ наличием средств защиты от сбоев, поддержки це- 
лостности и восстановления. Вігіеѵе, что весьма 
важно, позволяет использовать защиту от сбоев сете- 
вой ОС Ыоѵеіі ЫеіЛѴаге и, являясь частью ОС, де- 
лает это лучше, чем другие СУБД, поскольку не 
вступает в конфликт с ОС. Он использует средства 
управления транзакциями и осуществляет автооткат. 
Ыеі\Ѵаге Вігіеѵе может работать и с традиционными 
“рге-іта 2 е“- файлами, куда записывается содержи- 
мое буферов оперативной памяти, позволяет блоки- 
ровать отдельные записи и целые отношения 
(файлы), обладает защитой от тупиковых ситуаций 
(сіеасі-іоск). В зависимости от версии Ыоѵеіі ЫеіЛѴаге 
Вігіеѵе может восстанавливать БД при помощи спе- 
циальных утилит. В Вігіеѵе Ыоѵеіі Ыеі^аге версии 
2.15 — это утилита КЕСОѴЕК, позволяющая пе- 
реписать данные из “испорченного" файла Вігіеѵе в 
последовательный АЗСН-файл. Последний в свою 
очередь можно потом вновь загрузить в БД утилитой 
ШАЭ, организовав тем самым новый, уже 
“неиспорченный" файл Вігіеѵе. В версиях 2.2 и 3.11 
появилась новая утилита восстановления — ВКОББ- 
РК\ѴО. Она использует транзакции, поддержи- 
ваемые этими версиями ОС, и позволяет слить жур- 
нал транзакции с последней копией БД. Журнал 
транзакций ведется для каждого файла Вігіеѵе, ука- 
занного администратором сети, и хранится в специ- 


альной директории, также указанной админис- 
тратором сети; 

■ средствами реструктуризации, которые крайне огра- 
ничены и позволяют лишь добавлять и убирать 
ключи (индексы); 

■ выдачей статистики и контролем за состоянием БД с 
консоли файл-сервера; 

■ наконец, Вігіеѵе обеспечивает совмещение функций 
сервера базы данных и файл-сервера. Тем самым 
удешевляется реализация БД, так как используются 
ресурсы файл-сервера. 

Обладая такими незаменимыми достоинствами, как 
высокая надежность, дешевизна использования и вы- 
сокая производительность, а также наличие интер- 
фейсов с языками высокого уровня, Вігіеѵе имеет и 
ряд недостатков, в частности, в нем отсутствуют ути- 
литы проверки целостности, словарь данных (сіаіа сііс- 
ііопагу) и соответственно средства верификации 
информации. 

Кроме того, Вігіеѵе пугает многих разработчиков 
приложений тем, что не имеет дружелюбного интер- 
фейса пользователя. Решить эту проблему позволяет 
использование Вігіеѵе в сочетании с дополнительными 
продуктами Ыоѵеіі. К числу таких продуктов и 
относятся Х(2Ц и Хігіеѵе. Давайте рассмотрим 

архитектуру работы этих продуктов в среде Ыоѵеіі 
ЫеАѴаге. 


Для приложений, работающих на рабочей станции и передающих свои запросы к базе данных 
ВТРІЕѴЕ.ѴАР (ВТРІЕѴЕ.ЫІ-М), работающей на файл-сервере 


Файл-сервер Файл-сервер 



Рис. Іа Рис. 16 
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Архитектура рабе 
Хтгіеѵе, 50Ц л СИ 


аботы 


При запуске Хігіеѵе и Х(}Ь на рабочей станции 
должны быть запущены ядро Вігіеѵе (ВКЕ(21ІЕ5>Т.ЕХЕ 
для сетевого Вігіеѵе или ВТКІЕѴЕ.ЕХЕ для Вігіеѵе 
Зіп^іе Ѵегзіоп) и модуль работы с ЗС^Ь-примитивами 
Х(2Ы\ЕХЕ. Х(2ЬР выполняет функции интерфейса 
между Хігіеѵе, Х<ЗЬ и ядром Вігіеѵе — ВК.ЕС21ІЕЗТ, 
формирующим сетевой пакет для дальнейшей пере- 
сылки его при помощи оболочки ЫеПѴаге ЫЕТх на 
указанный сервер. Там запрос обрабатывается ѴАР- 
или ЫЬМ-процессами (специальными резидентными 
модулями, работающими под управлением ОС на 
файл-сервере), — ВЗЕКѴЕК или 8(}Ц ВК.ОІІТЕР, 
В5РХСОМ. Они, получив сообщение, проверяют па- 
раметры, выполняют операции ввода/вывода и воз- 
вращают результат программе ВКЕС^иЕЗТ на рабочей 
станции, а та передает управление обратно Хігіеѵе 
или Х(?Ь, т.е. модулю ХрЬР.ЕХЕ (рис. Іа). 
ХрЬР.ЕХЕ содержит более сорока функций-примити- 
вов. Функции-примитивы делятся на три категории: 

- примитивы словаря данных . Используются для 
поддержки и модификации словаря данных и для 


извлечения информации, которая содержится в 
словаре; 

- примитивы манипулирования данными . Ис- 
пользуются для описания и поддержки внешних 
схем, а также для осуществления запросов и под- 
держки файлов данных; 

- примитивы управления данными. Используются 
для установки или отмены защиты от НСД; включе- 
ния, изменения прав или исключения пользователей; 
присваивания или отмены прав доступа к файлам и 
полям базы данных. 

Если на файл-сервере работает 8(}Ц то архитектура 
имеет несколько другой вид. Не нужен модуль Х(}ЬР 
на рабочей станции. Его функции выполняются 3(2Ь 
на файл-сервере (рис. 1б, 2, 3). 

Хігіеѵе 

Теперь остановимся на Хігіеѵе. Это наиболее 
простой продукт из числа рассматриваемых. 

Хігіеѵе является средством создания и модификации 
множеств БД и внешних схем; выгрузки/загрузки 
множеств и манипулирования данными. С помощью 
Хігіеѵе вы можете быстро просматривать информа- 


Для приложений (ѴАР или ІЧІ-М), работающих под управлением сетевой ОС 
на файл-сервере (он же сервер базы данных) 

ФАЙЛ-СЕРВЕР ЛОКАЛЬНЫЙ ФАЙЛ-СЕРВЕР 




Рис . 2 


Рис . 3 


Приложение (\/АР или ІМІ.М) рабо- Приложение (ѴАР или ІМІ_М) выдает запрос для 
тает на том же файл-сервере, ВТНІЕѴЕ.ѴАР (ВТНІЕѴЕ . ІЧЬИ) - процесса, работающего 
что и ВТНІЕѴЕ.ѴАР (ВТРІЕѴЕ . М1_М) на другом файл-сервере 
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цию, осуществлять ввод, обновление и удаление дан- 
ных, осуществлять поиск информации, производить 
вычислительные операции с набором полей, проводить 
простейшую статистическую обработку элементов вы- 
борки, выводить на печать информацию из БД и по- 
лучать несложные отчеты. 

Авторы адаптировали Хігіеѵе для работы с русским 
алфавитом и используют его при создании простых 
приложений и администрировании сети. Но возникает 
ограничение при работе с русским алфавитом — 
отсутствие сортировки по русским буквам. (Его можно 
избежать, используя Вігіеѵе.) Рассмотрим условия, не- 
обходимые для функционирования Хігіеѵе. 

Для запуска Хігіеѵе необходим персональный ком- 
пьютер ІВМ РС ХТ/АТ или полностью с ним совмес- 
тимый, работающий под управлением операционной 
системы М5-ПОЗ или РС-Э05 версии 3.1 или выше. 
Хігіеѵе работает как с сетевой, так и с несетевой вер- 
сией Вігіеѵе. Хігіеѵе требует около 250 Кбайт, 
ХС^Р — 169 Кбайт и ВКЕдіІЕЗТ — 28 Кбайт опера- 
тивной памяти на одной рабочей станции. Более под- 
робно эти модули описаны ниже. Монитор может быть 
как цветным, так и монохромным. Хігіеѵе обладает 
следующими функциональными возможностями: 
м наличием языка описания данных, реализованного в 
виде системы меню, позволяющей определять мно- 
жества БД в виде реляционных отношений. Каждое 
множество (файл) вашей базы данных будет хра- 
ниться на диске под своим собственным именем. 
Определение файла включает описание каждого 
поля в файле. Необходимо присвоить имя каждому 
полю и определить для него тип хранимых данных и 
размер. Хігіеѵе поддерживает все форматы хранения 
Вігіеѵе (т.е. символьные строки, целое, десятичное, 
плавающее числа, дата, время, денежный и логичес- 
кий форматы, форматы двойной точности, строки в 
формате Си и Паскаля, строки переменной длины). 
Определяя файл в базе данных, вы должны сооб- 
щить Хігіеѵе, какие поля вы собираетесь использо- 
вать как ключевые; 

■ возможностью описывать информацию на уровне 
внешних схем. Внешняя схема — это как бы взгляд 
на существующую БД. Другими словами, внешняя 
схема дает возможность увидеть на экране нужные 
именно ему (без информации других пользователей) 
данные в том порядке и формате, которые указаны 


Файл : 

баг Раде 


Размещение : 

г : \даграде 



Тип 

Разм. Цес Раз-тель 

МАМЕ 

Сима . 

20 

5ТЙЕЕТ 

Симе 

10 

Н01І8Е 

Целое 

1 


Задайте имя поля - ЕЗС , если Вы закончили Вход 


Рис. 4. Пример описания внешней схемы 


1. Внеш. схема: Оос 


5 Сортировка : Ьох 

3 Ограничения : попе 



ИМЯ 

количество 

папка комментарий 

РЙ06ЯЕ55 

17 

9 

МІСЙ050РТ С 

3 

1 

26 

0 


Используйте клавиши редактирования для добавл новых данных в файл Вход 

Рис. 5. Ввод данных 

вами. Есть возможность изменять этот порядок, вы- 
бирать и включать в схему поля из одного файла 
или сразу из нескольких файлов (рис. 4); 

■ наличием словаря данных. В словаре содержится 
следующая информация о ваших множествах: имя, 
расположение файла на диске, описание полей. Соз- 
дав внешние схемы, определите ограничения на вы- 
бор информации или условия верификации, а 
Хігіеѵе добавит в словарь файлы, содержащие соот- 
ветствующую информацию. Хігіеѵе поддерживает 
три типа проверок вводимой информации — попа- 
дает ли вводимая информация в диапазон допусти- 
мых значений, соответствует ли списку допустимых 
символов или списку допустимых слов; 

■ защитой от несанкционированного доступа. Для 
этой цели определяются пользователи, имеющие 
право на доступ к информации и пароль, который 
должен указать пользователь, прежде чем он полу- 
чит возможность выполнять какие бы то ни было 
операции. Необходимо также определить, какие 
права получит каждый пользователь, а они могут 
быть следующими: общие права — дают возмож- 
ность добавлять новые множества в словарь и изме- 
нять описания существующих; права на измене- 
ние — позволяют изменять текущую конфигурацию 
Хігіеѵе; права на чтение/запись — предоставляют 
доступ к информации для ее чтения и записи. 
Право на запись включает в себя возможность чи- 
тать, добавлять, обновлять и удалять информацию; 

■ наличием языка манипулирования данными 5(2Б- 
типа, позволяющего в интерактивном режиме зада- 
вать критерии для формирования запросов. Кроме 
того, Хігіеѵе позволяет манипулировать данными 
при помощи макрокоманд — командных файлов, 
автоматически выполняющих заданную последова- 
тельность действий. Это дает возможность записы- 
вать и позже воспроизводить команды ввода (рис. 5) 
и операции просмотра (рис. 6) данных; 

■ наличием средств формирования отчетов; 

■ наличием средств интерактивной обработки 
(создание, удаление, реорганизация) множеств БД 
(рис. 7, 8). 

Хігіеѵе имеет ряд ограничений. Прежде всего это 
ограничения Вігіеѵе. При установке Вігіеѵе задаются 
максимальные значения ряда параметров исходя из 
специфики предполагаемой работы и имеющегося ре- 
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1 . Внеш . схема : бос 
3 Ограничения: попе 

имя 

РНОСРЕЗЗ 
МІСН030РТ С 
С-ггее РНЕ НАЫ01.ЕР 
г-тгее Реоог* Сепегаіог 

еишЕ то изімо ютоз і-2-з 

ЮЯВО РА5СА1. бзег ' з Оиійе 

ТІІРВО С 1.5 

ООАТТВО 

МісгозоРт Могб 

ТНЕ РЕХХ І_АИ(ЮАСЕ 

КЕОІТ 

СОЮР МОМ ТОР 

НЕМ1.ЕТТ-РАСКАР0 

НЗ-ЭОЗ ѵЗ 3 

С1Л0Е ТО ЕІЗ I N0 

ТНЕ СООВІЕВ Иетлогк 

ЫОѴЕИ ѵег 2.12 

НісгозоП СМ-ВАЗ I С 

6ВА5Е IV ѵ.1.0 I апдиаде РеЕегепсе 


5 Сортировка : Рох і 


количество панка комментарий 


Используйте ключи управления курсором для просмотра, Е8С - конец Проем 


Файл: Тезт 
б Индекс : 
путь 2 Поле 


Оирз Сазе Азе Зед 

Т панн -Меню 

—7 . -Словарь 

г— 6-Индекс 

І—ТЕ5Т 

I 1 Список 
3 Описание 
[ 4 Удаление 

Нот I і пе 
ІпзСаІ ( 

- Ністзг 
Опт Ех 
Оигтб 
Оигрг 
Оигшз 
ЗоЕтгзТ 
Тезт 


Введите имя для этого дополнительного индекса 


Поде к 


Рис. 6. Просмотр информации 

сурса памяти. Ограничения указаны для Вігіеѵе Ыоѵеіі 

ЫеіХѴаге версии 2.2: 

- максимальное число открытых файлов — может 
быть установлено в диапазоне от 0 до 255, по умол- 
чанию — 20; 

- максимальное число одновременно поддерживаемых 
файлов (в отличие от предыдущего параметра здесь 
один и тот же файл, открытый на двух различных 
станциях, считается как два поддерживаемых файла) 
может быть установлено в диапазоне от 0 до 3000, 
по умолчанию — 60; 

- максимальное число “заблокированных 44 записей — 
диапазон от 0 до 5000, по умолчанию — 20; 

- максимальное количество станций, одновременно ра- 
ботающих с Вігіеѵе, — диапазон от 0 до 100, по 
умолчанию — 15; 

- максимальный размер страницы — диапазон от 
512 байт до 4 Кбайт, по умолчанию — 4 Кбайта; 

- максимальное количество активных транзакций — 
диапазон от 0 до 42, по умолчанию — 0. Этот пара- 
метр определяет максимальное количество станций, 
которые могут одновременно иметь открытую тран- 
закцию; 

- максимальное число файлов, которые могут быть 
открыты внутри одной транзакции, — диапазон от 1 
до 18, по умолчанию — 12; 

- максимальная длина записи в сжатом файле — диа- 
пазон от 0 до 32 Кбайт, по умолчанию — 0; 

- максимальная длина записи — диапазон от 600 до 
55 296 байт, по умолчанию — 8192 байта. 

Ограничения накладывает и собственно Хігіеѵе: 

- он позволяет поддерживать одновременно любое 


—Г лавн -Меню 

1 . Внеш . схема 

2 . Отчет 

3 . Выход 

4 . Помощь 
5 Команды 

6 . Конфигурац 

7 . Словарь 

9 . Выполнение 


Работа с данными Вашей базы данных Меню 

Рис. 7. Главное меню Хігіеѵе для интерактивной 
работы с множествами БД 


Рис. 8. Введение дополнительного 
индекса в файл БД 

число баз данных путем настройки при запуске на 
конкретную базу. Количество файлов в базе данных 
не ограничивается, количество записей в файле 
ограничивается Вігіеѵе. В каждом файле могут быть 
заданы ключи, включающие комбинации полей раз- 
личного типа с набором атрибутов (возможность 
дублирования значения ключа, порядок сортировки и 
т.д.). Длина ключа — до 255 байт, можно опреде- 
лить до 24 ключей; 

- Хігіеѵе позволяет связывать по первичному ключу до 
8 файлов, т.е. до 8 файлов в одной внешней схеме; 

- экранная форма может содержать до 511 полей и до 
4096 байтов. Созданные экранные формы могут за- 
поминаться для использования в последующих сеан- 
сах работы. 

хсм. 

Другим продуктом, представляющим собой над- 
стройку к Вігіеѵе, является Х(}Б. ХС^Ь позволяет поль- 
зователю из своего приложения обратиться к БД при 
помощи 5<ЗБ-интерфейса. ХС^Ь отличается, и доста- 
точно заметно, от промышленного стандарта 5(}Б, — 
т.е. ЗДБ фирмы 1ВМ. Существенным его достоинством 
является то, что результаты запроса выводятся на лю- 
бое устройство. 

Х(}Б может использовать три уровня доступа к базе 
данных. 

1. Функции-прймитивы, поддерживаемые програм- 
мой Х(}БР, описанные выше. Это самый низкий уро- 
вень доступа к базе. Их вызов осуществляется непо- 
средственно из языка программирования (Си, Бейсик, 
КОБОЛ, Паскаль). 

Например, вызов функции хОО, создающей и уда- 
ляющей словарь данных, осуществляется из языка С 
следующим образом: 

іпі хББ (зРаШіагае, ЮрМоп) 
сЬаг зРаіЬпагаѳ; 
іпі ЮрМоп; 

- параметр зРаіЬпаше определяет директорию на 
диске, в которой создается или удаляется словарь; 

- параметр іОрііоп может принимать три значения: 0, 
1 или 2. Если іОрііоп = 0, создается словарь только 
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ПАКЕТЫ Хігіеѵе, Х<ЗЬ И $<ЗЬ 


ХОі Ітегассіѵе ітегЕасе — 
ЕпТег Оо Сіеаг Весаіі 8тоге Оеіете Оріюпз Оиіт 

8Е1.ЕСТ Оосіог , Иванов 

РВОМ Арроілішет А. Раііелс Р 
КИЕВЕ А. ІО = Р 10 


Еп*ег ап 801 зсаіетепі: . Ргезз <Езс> ѵЛіеп боле 

Рис. 9. 8(2Ь-запрос в интерактивном ХС^Ь 

в том случае, если в указанной директории словарь 
отсутствует; если Юрііоп = 1, новый словарь созда- 
ется в любом случае; если Юрііоп = 2, словарь уда- 
ляется. 

В случае успешного завершения функция хОЭ воз- 
вращает значение 0. 

2. Программа Х(2Б Мапа^ег (Х(}Ш). Эта прог- 
рамма представляет собой интерфейс более высокого 
уровня между прикладной программой и Х(}ІЛ\ Она 
состоит из группы функций, позволяющих прикладной 
программе исполнять ЗДЬ-предложения, т.е. в пара- 
метрах функций, вызываемых из Си (Бейсик, Паскаль 
или КОБОЛ), указываются непосредственно опера- 
торы языка 

Х(}БМ поддерживает АЫ8ІІ-стандарт 8(2Ь, расши- 
ренный дополнительными функциональными возмож- 
ностями. ХС^ЬМ преобразовывает их в соответству- 
ющие функции-примитивы ХС^ЬР. Последние выпол- 
няют необходимые операции нижнего уровня над 
файлами и данными на рабочей станции или пере- 
дают запрос на файл-сервер, где он обрабатывается по 
описанной выше схеме. Затем результаты возвраща- 
ются функции Х(}ЬМ, которая в свою очередь возвра- 
щает его прикладной программе. 

Например, выполнение 5(}Ь-запроса из языка Си 
может быть выполнено вызовом следующей функции: 

іпі ХОЬСогаріІе (ІСигзог, ІБѢаІегаепѣЬеп, зБ'ЬаІегаепѣ) 

іпі ІСигзог; 

іпѣ •іЗіаІегаепІЬеп; 

сЬаг •зБІаІѳгаепІ; 

зБѣаІѳпѳпѣ - 

"ЗЕЬЕСТ Иванов ЕКОМ Арроіпіяѳпі А, РаМепІ Р ЯНЕКЕ А. ІБ - Р. ІБ" 

3. Интерактивный интерфейс Х(}Ы. Он позволяет 
прикладной программе в интерактивном режиме выда- 
вать запросы к БД и обновлять информацию, исполь- 
зуя ЗС^Ь-предложения. Результаты этих действий вы- 
даются на экран монитора. 8(2Ь- предложен и я исполь- 
зуются для вызова соответствующих функций Х(}І_М, 
который в свою очередь вызывает ХС^ЬР. Обычно 
Х(2ІЛ используется для тестирования 8(ЗБ-предложе- 
ний, просмотра файлов, отладки программ. При этом 
$(}Б-предложения могут вводиться как с экрана мони- 
тора в интерактивном, так и из файла в пакетном ре- 
жиме (рис. 9). 

Как и Хігіеѵе, Х(2Б поддерживает словари данных и 
обеспечивает защиту от НСД. ХС^Б имеет интерфейсы 


с различными версиями языков Си, Бейсик, Паскаль и 
КОБОЛ. 


501 

К сожалению, ХС^Ь занимает достаточно много опе- 
ративной памяти на рабочей станции, и, чтобы 
освободить память рабочей станции, Ыоѵеіі разрабо- 
тала специальный БС^Б-сервер (ѴАР-процесс для Ыеі- 
Ѵ/аге 286 или загружаемый модуль ЫЬМ для ЫеМаге 
386), который позволяет обрабатывать БС^Ь- запросы 
непосредственно на файл-сервере, а не на рабочих 
станциях. Рассмотрим его работу в среде Ыеі^аге 286. 
Программы Х(ЗЬМ и ХОЦР объединяются в единый 
ѴАР-процесс, называемый Ы\Ѵ$8(2Б и “убираются* 3 4 с 
рабочей станции. Для осуществления связи между 
Ы\Ѵ$5(2Ц работающим на сервере, и прикладной прог- 
раммой — на рабочей станции, на последней должна 
быть загружена резидентная программа Ы8КЕ(). Не- 
посредственный доступ к файлам базы данных осу- 
ществляется через два ѴАР-процесса Вігіеѵе — 
В8ЕКѴЕК. и В&ОІЛГЕВ. В8ЕКѴЕК осуществляет до- 
ступ к файлам на ввод/вывод, поддерживает блокиро- 
вание файлов или записей, имеющих многих пользо- 
вателей, взаимодействует с системой защиты от сбоев 
Ыеі\Ѵаге — ТТ8, обеспечивая автооткат и 
восстановление при сбоях файл-сервера. ВКСШТЕЯ 
представляет собой интерфейс между ѴАР-процессом 
Ы\Ѵ$8(2Ь и ѴАР-процессом В8ЕКѴЕК, загруженный 
на каждом сервере в сети. Авторы на собственном 
опыте убедились, что ѴАР-процессы в Ыеі\Ѵаге имеют 
множество недостатков: ограничения по памяти, не- 
возможность загрузить их после запуска ОС, необхо- 
димость дополнительных инструментальных средств 
для их разработки. Фирма Ыоѵеіі для 386-х версий 
Ыеі\Ѵаге использует другой аппарат — 8(2Ь ЫШ — 
Ые(\Ѵаге БоасІаЫе Мобиіе. Эти модули подзагружаются 
к операционной системе на сервере, но лишены 
ограничений, накладываемых на ѴАР-процесс. Как и 
БС^Б.ѴАР, БрБ.ЫЬМ обеспечивает реализацию фун- 
кций ХС^Б на файл-сервере и поддерживает работу на 
уровне как функций-примитивов, так и 8(2Б- 
предложений и интерактивного доступа к БД. Его 
основными компонентами на файл-сервере являются 
ВТКІЕѴЕ.ЫШ и ВКОІГГЕК.ЫШ. На рабочей стан- 
ции работает резидентная программа Ы8КЕ(). Для вы- 
полнения коммуникационных функций между серве- 
ром и рабочей станцией используются В8РХ- 
СОМ.ЫЬМ, а для организации работы в много- 
пользовательском режиме — Ы88РХСОМ. 

Таким образом, комбинация описанных выше про- 
дуктов поможет вам получить эффективное и удобное 
средство работы с БД в среде Ыоѵеіі ЫеіЛѴаге. 

М. Беленькая, А.Бухман, Т.Карпова 

Телефоны: 

923 - 10-86 

923 - 02-08 
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БИБЛИОТЕКА 

РАКАООХ ЕИОІИЕ 2.0 


Библиотека Рагаёох Еп^іпе отк- 
рывает возможность использова- 
ния данных Рагасіох в программах, 
которые написаны на языках 
Разсаі, С, и в среде МісгозоК \Ѵіп- 
сіо\ѵз 3.0. Создание этой библи- 
отеки — одно из проявлений стра- 
тегии Вогіапё на достижение вза- 
имосвязи между прикладными 
программами и языками програм- 
мирования. 

Библиотека состоит из более 
чем 70 функций, позволяющих ис- 
пользовать данные, подготовлен- 
ные с помощью СУБД Рагасіох, 
как в однопользовательском, так и 
в многопользовательском режимах. 

Библиотека позволяет: 

■ создавать, читать и сохранять 
таблицы, записи и поля Рагасіох; 

■ поддерживать разделение фай- 
лов и записей между Рагасіох, 
РАЬ и прикладными программа- 
ми, написанными с использова- 
нием Рагасіох Еп^іпе; 

■ обмениваться данными с 
пакетами (^иаНго Рго, ЗібеКіск 
и Рагасіох; 

■ поддерживать такие возможнос- 
ти Рагасіох, как парольная за- 
щита, шифровка таблиц, коди- 
рование данных, поиск и обра- 
ботка ошибок; 


■ импортировать данные в табли- 
цы Рагасіох через последователь- 
ный порт, как, например, при 
связи с большими машинами 
или с внешними устройствами, 
недоступными РАЬ; 

■ создавать независимые приклад- 
ные программы или программы, 
выполняемые командой РАЬ 
КІШ. 

Новая версия библиотеки под- 
держивает такие языки програм- 
мирования, как ТигЬо Разсаі 5.5, 
ТигЬо Разсаі 6.0, ТигЬо С 2.0, 
ТигЬо С++, Вогіапсі С++ и 
МісгозоН С. При использовании 
динамических библиотек, входя- 
щих в комплект поставки, возмож- 
но написание программ для 
>Уіпсіо>ѵ5 3.0. 

Функции библиотеки 

Ниже рассматриваются основ- 
ные группы функций, входящих в 
состав библиотеки. 

Операции с таблицами 

Библиотека позволяет выпол- 
нять базовые операции над табли- 
цами Рагасіох. Возможно создание, 
открытие и закрытие таблиц. 
Также имеются функции для ко- 


пирования таблиц, переименова- 
ния, добавления записей из одной 
таблицы в другую, удаления всех 
записей в таблице и шифрования 
таблицы. 

Операции с записями 

При помощи функций Рагасіох 
Еп^іпе возможно выполнение опе- 
раций над записями в таблице. 
Эти операции включают в себя 
перемещение по записям в таб- 
лице, перемещение к первой и по- 
следней записи, перемещение к 
предыдущей и следующей записи. 

Операции с полями 

Функции библиотеки обеспечи- 
вают возможность чтения и за- 
писи содержимого полей записи. 
Имеются функции для определе- 
ния типа поля и для определения 
того, содержит поле данные или 
нет. 

Имеются функции чтения и за- 
писи для всех типов полей (Ы, $, 
5, А и Э). 

Операции 

преобразования данных 

В состав библиотеки включены 
две функции для преобразования 
даты из внутреннего формата и 
обратно. 
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БИБЛИОТЕКА РАКАООХ ЕМСШЕ 2.0 


Таблица 1 . Соответствие функций Рагабох Епдіпе и Рагабох 


| Функция Епдіпе 

Функция/команда РАІ_ 

Меню Рагабох 

Операции с таблицами 

РХТЫСгеаТе 

СРЕАТЕ 

СгеаТе 

РХТЫЕтрТу 

ЕМРТУ 

Тооі з-Моге-ЕтрТу 

РХТЫОеІеІе 

ОЕІ_ЕТЕ 

Тооі з-ОеІ еТе-ТаЬ 1 е 

РХТЫСору 

СОРУ 

Т оо 1 з-Сору-ТаЬ 1 е 

РХТЬ 1 Репате 

РЕЫАМЕ 

Тооі з-Репате-ТаЫе 

РХТЫАсІс! 

/КОО 

Тооіз-Моге-Абб 

Операции с записями 

РХРесАррепб 

ЕМ ІМ 


РХРесІпзег т 

ІМ 


РХРесОото 

МОѴЕТО РЕСОРЭ питЬег 


РХРесЫехТ 

ЗКІР +1 


РХРесРгеѵ 

ЗКІР -1 


РХРесОеІеТе 

йЕІ_ 


Операции с паролем 

РХТЬ 1 РгоТесТеб 

I ЗЕІМСРУРТЕй 


РХРзѵа/Асісі 

РАЗЗѴЮРО 


РХРзѵЛЭеІ 

ішраззілЮро 


РХТЫЕпсгурТ 

РРОТЕСТ 

Тооі з-Моге-РгоТест-Раззюогб 

РХТЬЮесгурТ 


Тооі з-Моге-РгоТесТ-СІ еаг Раззѵюгбз 


Информационные 

операции 

РХТЫЕхізТ 

ІЗТАВЬЕ 


РХТЬ 1 Мате 

ТАВЬЕ 


РХРесІМит 

РЕСМ 


РХТЬШРесз 

МЕС0Р03 


РХРесМРіеІ бз 

МРІЕЮЗ 


РХКеуМР іеібз 

ЫКЕУРІЕЮЗ 


РХР ІбНапбІе 

РІЕІЛЖО 


РХРІбТуре 

РІЕЮТУРЕ 


РХРІсШате 

Р ІЕІ_0 


РХТЫ МахЗіге 

ЗЕТМАХЗІ2Е 


Операции в среде локальной сети 

РХМеТІІзегМате 

ЬЗЕРМАМЕ 


РХЫеТРі ІеІ_оск 

юск 

Тооі з-ЫеТ-Ьоск 

РХЫеТР і 1 еЬп 1 оск 

ьмоск 

Тооі з-МеТ-Ьоск 

РХМеТРесОоТоЬоск 



РХЫеТТЬ 1 1_оск 

юск 

Тооі з-МеТ-Ьоск 

РХМеТТЬШпІоск 

шмюск 

Тооі з-ЫеИ-Ьоск 

РХЫеТТЬ 1 Ре^гезЬ 

РЕРРЕЗН 


РХМеТРесЬоск 

ЮСКРЕСОРО 


РХМеТРесІІп Іоск 

умоскресоро 


Операции обработки ошибок 

РХЕггМзд 

ЕРР0РМЕЗЗА0Е 


РХМеТЕг гіізег 

ЕРРОРУЗЕР 



Операции с индексами 

Эти операции позволяют созда- 
вать и удалять первичный и вто- 
ричный индексные файлы. 

Операции поиска 

Операции поиска позволяют ис- 
кать запись, которая содержит од- 
но или более указанных значений 
полей. Также возможен поиск с 
начальной записи или с текущей 
записи таблицы до первого 
совпадения. 


Операции с паролем 

Имеется возможность шифрова- 
ния таблицы при помощи пароля, 
доступа к защищенным по паролю 
таблицам и определения необходи- 
мости указания пароля для дос- 
тупа к таблице. 

Операции в среде 
локальной сети 
Эта группа операций предна- 
значена для работы программы в 
локальной сети. Поддерживаются 


разделение доступа к таблицам, 
разделение доступа к записям и 
возможность получения информа- 
ции о сети. 

Операции 
обработки ошибок 

Имеется возможность обработки 
ошибок, возникающих при работе 
любой функции библиотеки. Оши- 
бки разделяются на три класса: 
фатальные, пользователя и прог- 
раммы. 
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Технические 

характеристики 

Для работы Рагасіох Еп^іпе тре- 
буется компьютер типа ІВМ РС, 
Р5/2 или 100% -совместимый с 
ними, 512 Кбайт памяти, жесткий 
диск и один дисковод. 

Библиотека работает под управ- 
лением 005 версии 3.0 и выше. 
При использовании динамических 
библиотек требуется ХѴіпсІошз вер- 
сии 3.0 и выше. 

Требования к сети 
Рагасіох Еп^іпе может работать 
в среде: 

- ЗСот ЗРІиз версии 1.0 и выше; 

- Ыоѵеіі Абѵапсесі ЫеЬѵаге версии 
не ниже 2.0А; 

- ІВМ Токеп Кіпв или РС ЫеЬѵогк; 


- Вапуап ѴІЫЕ5 2.10; 

- АТ&Т ЗіагЬап 1.1; 

- любой другой сети, 100% -сов- 
местимой с 005 3.1, и одной из 
перечисленных выше сетей. 

Характеристики данных 
Число одновременно используемых 
таблиц ограничено размером па- 
мяти. 

Число записей в таблице — до 
2 миллионов. 

Число полей в записи — 255. 
Число символов в поле — 255. 
Число байт в записи — 4000, 
1350 индексированных. 

Характеристики 
Рагасіох Еп§іпе 

До 64 одновременно открытых 
таблиц. Максимальный размер бу- 


фера для своппинга составляет 
256 Кбайт. Число “защелок 44 для 
файла — 128. Поддержка сорти- 
ровки. 

Заключение 

Библиотека Рагасіох Еп^іпе 
представляет интерес для пользо- 
вателей Рагасіох, которым не 
хватает мощности языка РАЕ Воз- 
можность использования библио- 
теки с наиболее распространенны- 
ми языками программирования и 
создание программ, работающих в 
среде \Ѵіпс1о\ѵ5, делает ее неза- 
менимым средством создания 
прикладных программ, основан- 
ных на данных Рагасіох. 

А Федоров 


НАУЧНО-МЕТОДИЧЕСКИЙ 
И РЕКЛАМНО-КОММЕРЧЕСКИЙ ЦЕНТР 



ПРЕДЛАГАЕТ ПО ДОСТУПНЫМ 
ЦЕНАМ 

ВСЕМ ПОЛЬЗОВАТЕЛЯМ 
КОМПЬЮТЕРНОЙ ТЕХНИКИ 

■ разработку, поставку и адаптацию 

к условиям заказчика автоматизированных 
рабочих мест: бухгалтера, кадровика, 
складского работника 

■ профилактическое обслуживание 
с ремонтом РС ХТ/АТ 286 

■ систему передачи данных между 
компьютерами (по К5-232; 

до 10 персональных компьютеров 
на расстояние до 50 м) 

■ срочное восстановление лент принтеров 


Пишите по адресу: 109180 Москва, а/я 34 
Звоните по телефону: 233-03-39, 233-52-03 
Факс: 233-52-03 


ВНИМАНИЮ ПОЛЬЗОВАТЕЛЕЙ 
ПЕРСОНАЛЬНЫХ ЭВМ 

Завод “Крон“ освоил производство гибких 
магнитных дисков, отвечающих всем 
требованиям международных стандартов. 
Производится стопроцентная сертификация 
поверхности на оборудовании фирмы 
МЕМССЖ (США). 

Завод “Крон 44 предлагает гибкие магнитные диски 
размером 133 мм (5.25 дюйма): 

“Электроника МС 5801.01“ — двусторонние 
40 дорожек на поверхность (48 ТРІ, боиЫе зібе), 
неформатированная емкость до 500 Кбайт. 

150 7487. 

“Электроника МС 5801.02“ — двусторонние 
80 дорожек на поверхность (96 ТРІ, сІоиЫе зісіе), 
неформатированная емкость до 1000 Кбайт. 

150 8378. 

Дискеты очистные размером 133 мм (5.25 дюйма) 
“Электроника- 130“ — надежное средство для 
очистки головок накопителей любого типа. 
Ежедневная чистка головок гарантирует Вам 
надежную работу накопителей в компьютере. 

Минимальное количество в заказе — 500 штук. 
Наложенным платежом дискеты не высылаются. 

Наш расчетный счет №263921 в Промышленном 
отделении ПСБ, МФО 256122. 

Заявки высылать по адресу: 362046, СОССР , 
Владикавказ , Архонское июссе, 1 , завод "Крон" 

Телефон: (867-22)4-49-13 
Телетайп : 265201 МИР 
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МЕЖДУ ПРОЧИМ... 



Между 

прочим... 


СЧАСТЛИВЫЙ 

СОЫТКОі-1 


Предположим, вы хотите передавать информацию 
со своего персонального компьютера на другой, 
программ но- несовместимый компьютер, например, на 
миникомпьютер из широко распространенной серии 
СМ ЭВМ. Не начинайте сразу выпрашивать у своих 
знакомых специальные коммуникационные про- 
граммы, задавать глубокомысленные вопросы про ло- 
кальные сети и подыскивать квалифицированных спе- 
циалистов. Попробуйте сначала четко сформулиро- 
вать, что же вы хотите получить в результате. По- 
нятно, о переносе выполняемых файлов не может 
быть и речи — работать они все равно не будут. Если 
же предел ваших желаний — передача исходных тек- 
стов программ или экспериментальной информации, 
представленной в символьном виде, то, перефразируя 
классика, “...у вас есть все основания считать, что вы 
и один справитесь с этим делом 44 . 

Первое, что вы должны выяснить, — через какой 
интерфейс подключены дисплеи пользователей на ми- 
никомпьютере (в случае многопользовательской 005) 
или имеется ли свободный последовательный порт. 
Физическая реализация последовательного интерфей- 
са, как правило, осуществляется в соответствии со 
стандартом К8232С (аналог стык С2) или ИРПС (“то- 
ковая петля“). В последнем случае вам придется про- 
консультироваться у электронщиков — возможно ли 
переключение ИРПС-стык С2 (некоторые платы ком- 
пьютеров допускают это). Если это не так, то надо 


либо докупить соответствующую плату (для одного из 
компьютеров), либо модернизировать старую (что, во- 
обще говоря, не сложно: понадобятся две микросхемы 
приемопередатчиков — ПОУП 2 и 170АП2 или не- 
сколько транзисторов). 

Следующая возможная, но вполне преодолимая 
трудность — перекодировка пересылаемого текста, 
связанная с несовпадением А$СІІ-кодов некоторой ча- 
сти символов (или вообще отсутствием литер с кодами 
от 128 до 255). Останавливаться на этом нет смысла, 
так как по данному вопросу выпущено большое коли- 
чество справочных изданий. 

Лучший вариант, если у вас имеется “нуль-модем- 
ный“ кабель для соединения портов компьютеров. 
Если его нет, то придется его изготовить. Дело это со- 
всем несложное, хотя и не без некоторых тонкостей. 
Основные проблемы обычно связаны с использованием 
сигналов синхронизации: “Запрос на передачу* 4 КТ5, 
“Готов к передаче 44 СТ5, “Готовность компьютера 44 
05К, “Контроль приема 44 ОСЭ и “Терминал готов 44 
ОТК (соответственно, контакты 4, 5, 6, 8 и 20). Не- 
редко компьютер не может обмениваться информа- 
цией с абонентом только потому, что не установлены 
соответствующие уровни определенных сигналов син- 
хронизации, обусловливающих момент начала пере- 
дачи данных. В этом случае следует объединить 
(замкнуть) один из контактов выходного синхронизи- 
рующего сигнала с одним или несколькими входными. 
Иными словами, это будет означать, что подсоединен- 
ный абонент всегда находится в состоянии готовности. 
Для терминалов миникомпьютера обычно объединяют 
контакты 6 и 20, для разъема К5232С на РС замы- 
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кают еще контакты 4, 5, и 8. Напомним, что сигналы 
“Передаваемые данные 44 Ях, “Принимаемые данные 44 
Тх и “Сигнальная земля 44 Спсі соответствуют контак- 
там 2, 3 и 7 (5 в случае 9-контактного разъема). Для 
платы последовательных портов миникомпьютера но- 
мера контактов желательно уточнить по 
техдокументации. Безусловно, что контакт сигнала Тх 
на одном разъеме соединяется с контактом сигнала Ях 
на другом и наоборот (см. также Компьютер- 
Пресс №8'91, с. 70). 

Из “математики 44 на ІВМ РС вам понадобится 
только утилита МОЭЕ.СОМ — для установки необхо- 
димых параметров порта СОМ1 (или СОМ2). Кстати, 
установка параметров последовательного порта на ми- 
никомпьютере, как правило, выполняется микропере- 
ключателями или запаянными перемычками, поэтому 
удобнее “подстраиваться 44 под них именно на РС. Не 
забудьте это сделать перед началом каждой передачи. 

Итак, можно приступать. Сначала необходимо вы- 
полнить на одном из терминалов миникомпьютера ко- 
манду типа 

СОРУ ТТх РІБЕОЕ8Т, 

где СОРУ — имя системной команды копирования 
(оно, конечно, зависит от операционной системы); 
ТТх — логическое имя пользовательского терминала 
(или имя последовательного порта), вместо которого 
подключен РС; РІБЕОЕ5Т — имя файла, куда вы хо- 
тите записать принимаемые данные. 

Теперь можно начинать работу на РС. Правильно, 
пора выполнить команду 

СОРУ РІБЕ5КС СОМ1 (или СОМ2) 

Но вот беда! Команда СОРУ М5 Э08 копирует 
АЗСІІ-файлы и в некоторых случаях (не претендую на 
всеобщность), вне зависимости от положения ключа 
/А в командной строке, “не хочет 44 добавлять символ 
конца файла СопІгоІ-2 (СТЯБ-2, шестнадцатиричный 
код — 1АН) через СОМ-порт. В результате на мини- 
компьютере принятый файл не может быть закрыт со 
всеми отсюда вытекающими последствиями. 

Как известно, из любого положения можно найти 
не менее трех выходов. Приведем здесь только два и 
надеемся, что третий (возможно, более простой) вы 
найдете сами. 

Первое, что приходит в голову, — это послать сим- 
вол СТЯБ-2 вслед за переданным файлом принуди- 
тельно, используя для этого, например, прерывание 
ВІ05 14Н (хотя можно обращаться и непосредственно 
к портам). При использовании отладчика ОЕВСІС для 
этого потребуется не более пяти минут. 

- А 

хххх:0100 МОѴ АН,1 
хххх:0102 МОѴ ЭХ,0 
хххх.0105 МОѴ АЦ1А 
хххх:0107 ЮТ 14 
хххх:0109 МОѴ АХ,4С00 
хххх:010С ЮТ 21 
ххххЮЮЕ 

- КСХ 
СХ 0000 
:Р 

- N СТКБ-2.С0М 


- \Ѵ 

\ѴгШпв 000Р Ъуіез 

- <3 

Р 

В этом случае ВАТ-файл для передачи может вы- 
глядеть, например, следующим образом: 

@ЕСНО ОРР 
МОИЕ СОМ1 :24,Е,7,1 
СОРУ %1 СОМ1 
СТКБ-2.С0М 

Однако возможен более простой путь, и ВАТ-файл 
для этого случая приведен ниже. 

@ЕСНО ОРР 
МОЭЕ СОМ1:24,Е,7,1 
СОРУ %1+„ 

СОРУ % 1 /В СОМ1 

Третья строка ВАТ-файла копирует файл, предпо- 
лагаемый для передачи, сам в себя, добавляя в его ко- 
нец символ СТЯБ-2. Последняя строка командного 
файла копирует передаваемый файл на СОМ-порт как 
двоичный (ключ /В), т. е. символ СТЯБ-2 тоже будет 
скопирован. 


МЕНЮ - "СДЕЛАЙ САМ" 


Часто в командных файлах (ВАТ-файлах), описы- 
ваемых в литературе, упоминается некая программа, 
называемая, например, АЗКСОЭЕ. Эта программа 
применяется в ВАТ-файлах обычно для создания про- 
стейших меню, так как умеет возвращать код нажатой 
пользователем клавиши. Возвращаемый код впослед- 
ствии может быть использован при проверке условия 
типа іГ еггогіеѵеі... &о1о... для перехода на выполнение 
соответствующей прикладной программы. Один из 
возможных вариантов простейшего меню может быть 
реализован в виде следующего ВАТ-файла: 


@ЕСНО ОРР 
:5ТАЯТ 

сьз 

ЕСНО НАЖМИ КЛАВИШУ N ДЛЯ ВХОДА В ЫОІПХЖ 

СОММАЫОЕВ 

ЕСНО 

ЕСНО НАЖМИ КЛАВИШУ \Ѵ ДЛЯ ВХОДА В \ѴОКЭ 
ЕСНО 

ЕСНО НАЖМИ КЛАВИШУ 8 ДЛЯ ВХОДА В ^РЕВСЛЬС 
А5К СООЕ 

ІР ЕВВОВБЕѴЕЬ 1 19 ІР ІМОТ ЕВВОВБЕѴЕЬ 120 СОТО \ѴОВЭ 

ІР ЕВВОВБЕѴЕЬ 115 ІР !ЧОТ ЕВВОВБЕѴЕЬ 116 СОТО 51ФС 

ІР ЕВВОВБЕѴЕЬ 1 10 ІР Ж)Т ЕВВОВЬЕѴЕЬ 1 1 1 СОТО 1МОВТ 

СОТО 5ТАВТ 

:ШВТ 

С:\ЫСЗ\1^С 

СОТО Е1ѴШ 

:5СРС 

0:\ЗС4\5С 

СОТО ЕЫО 

:\ѴОВЭ 

С:\\ѴОВ05\Ж)ВО 

:ЕЫБ 


После запуска такого ВАТ-файла на экране дис- 
плея появятся надписи, предлагающие нажать на одну 
из трех латинских букв (п, 5 или лѵ), в зависимости от 
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МЕЖДУ ПРОЧИМ... 


того, с каким программным продуктом (Ыогіоп Сош- 
тапсіег, ЗирегСаІс или ЛѴогсі) вы намерены начать ра- 
боту. При проверке условий (іі еггогіеѵеі) использу- 
ются АЗСІІ-коды вышеназванных клавиш. В случае 
если будет нажата любая другая клавиша, то эти над- 
писи появятся вновь. Несложно внести небольшие до- 
бавления в этот ВАТ-файл, чтобы, например, при на- 
жатии на клавишу ^ завершить его работу. 

Программу АЗК_СОБЕ можно, конечно, написать 
на любом из языков высокого уровня, таких, 
например, как Си или Паскаль. Однако мы пойдем 

другим путем (как ни одиозно звучит сейчас эта 

фраза), используя для создания такой программы 
возможности утилиты ООЗ — БЕВБЮ. Для этого 
необходимо в любом текстовом редакторе создать 

АЗСІІ-файл с именем А5КС0БЕ.БВС следующего 

содержания: 

А 

МОѴ АН, 8 
ШТ 21 
МОѴ АН,4С 
ШТ 21 

«ЗДЕСЬ ПУСТАЯ СТРОКА» 

ЕСХ 

8 

ХАЗС СОБЕ СОМ 
\Ѵ _ 

После выполнения командной строки ОБ- 
ВЕЮ < АЗССОБЕ.БВС в той же директории будет 
создан программный файл АЗССОБЕ.СОМ, из ас- 
семблерного текста которого следует, что для получе- 
ния АЗСІІ-кода нажимаемой клавиши в нем 
используется функция 8Н прерывания 2 1 Н, которая 
при выходе помещает этот код в регистр АЕ. 

Однако если в приведенном выше ВАТ-файле вы по 
каким-либо причинам вместо букв захотите 
использовать служебные клавиши или комбинации 
клавиш (например Р1, ЗНіГі-п, АН-з и т.п.), то про- 
грамма АЗССОБЕ будет работать неправильно. Дело 
в том, что как комбинации клавиш, так и служебные 
клавиши не имеют собственных АЗСІІ-кодов, но могут 
характеризоваться так называемыми расширенными 


АЗСІІ-кодами (ЕхІепсІесІ А5СІ1). Признаком того, что 
нажата служебная клавиша или комбинация клавиш 
после вызова функции 8Н, является нулевое 
содержание регистра АЕ. Значение расширенного 
АЗСІІ-кода можно получить в этом случае после 
повторного вызова функции 8Ь. Следовательно, файл 
с расширением БВС для создания программы 
АЗК_СООЕ будет выглядеть, например, так: 

А 

МОѴ АН, 8 
ШТ 21 
СМР АБ,0 
Ш2 ЮС 
МОѴ АН, 8 
ШТ 21 
МОѴ АН,4С 
ШТ 21 

«ЗДЕСЬ ПУСТАЯ СТРОКА» 

КСХ 

10 

ХАЗК СООЕ.СОМ 
\Ѵ 

О 

Хотя если вы вполне уверены в совместимости 
своей персоналки с “писишкой“ ІВМ на уровне ВІ05, 
то без особых раздумий можете использовать функцию 
ООН прерывания 16Н для одновременного получения 
как АЗСІІ-кода, так и расширенного АЗСІІ-кода (если 
он, конечно, имеет место) клавиш. В этом случае 
файл АЗССОБЕ.БВС может выглядеть следующим 
образом: 

А 

МОѴ АН, О 
ШТ 16 
СМР АБ,0 
Ш2 10А 
МОѴ АБ,АН 
МОѴ АН,4С 
ШТ 21 

«ЗДЕСЬ ПУСТАЯ СТРОКА» 

КСХ 

Е 

ХАЗК СОБЕ.СОМ 
\Ѵ 

С 


А.Борзенко 


Фирма Оі^ііаі Едиіртепі 
Согрогаііоп, второй по величине 
производитель компьютеров в 
США, собирается выйти на рынок 
с совершенно новым микропроцес- 
сором, получившим название 
АБРНА. Этот 64-разрядный мик- 
ропроцессор выполнен по так 
называемой АКА-архитектуре (Асі- 
ѵапсесі КІЗС АгсНіІесіиге), разра- 
ботанной самой фирмой БЕС. По 
мнению фирмы, микропроцессор 
АБРНА сможет работать с такто- 
вой частотой до 200 МГц, что поз- 
волит достигнуть производитель- 


ности около 400 МІРЗ. По оцен- 
кам специалистов фирмы Сгау Ке- 
зеагсН один АБРНА-микропроцес- 
сор имеет такую же вычислитель- 
ную мощность, как суперЭВМ 
Сгау-1, поэтому он окажется 
предпочтительней микропроцессо- 
ров других фирм, таких как Зип, 
Не^іеіі-Раскагсі и ІВМ. Кроме то- 
го, из заявления фирмы Іпіеі — 
ведущего производителя полупро- 
водниковой техники — следует, 
что ее микропроцессоры нового 
поколения рассчитаны на произво- 
дительность всего в 100 МІРЗ. От- 


ношение же специалистов Іпіеі к 
использованию параметров микро- 
процессора АБРНА в полном объ- 
еме — более чем скептическое. 

Также, немалые надежды возла- 
гаются на то, что микропроцессор 
АБРНА, помимо поддержки прог- 
раммных продуктов БЕС, включая 
ѴМ5, в состоянии обеспечить бу- 
дущее для операционной системы 
фирмы МісгозоГІ — ЛѴіпсіо^з ЫТ. 
Это смогло бы резко повысить 
спрос на новый микропроцессор. 

ТНе Ѵ/аІІ Зігееі /оигпаі, 
РеЬгиагу, 1992 
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АО «ПИРИТ» 


Расширение возможностей ІВМ-совместимых 
персональных компьютеров 

ИСПОЛЬЗУЙТЕ КОМПЬЮТЕРЫ БОЛЕЕ ЭФФЕКТИВНО 

♦ РАСШИРЕНИЕ ОПЕРАТИВНОЙ ПАМЯТИ 

дает неисчерпаемые возможности при работе с современным программным 
обеспечением от оболочек типа \Ѵ1ЫОО\Ѵ5 и издательских систем до сетевого 
программного обеспечения. 

Обратитесь к нам, мы откроем Вам новые возможности! 
РАСШИРЕНИЕ ОПЕРАТИВНОЙ ПАМЯТИ - это то, что мы сделаем для Вас. 

В НАШЕЙ ПАМЯТИ - ВАША ЭФФЕКТИВНОСТЬ! 

Всегда в наличии комплектующие динамической памяти: 
Микросхемы Модули Платы расширения 


♦ 

4164 

♦ 

$ІММ 

256 К 

ЕхтепсіеЬ/ЕхрапЬесі совместимые с 1_ІМ 4.0 

♦ 

4464 

♦ 

5ІРР 

256 К 

♦ 0 -*• 2 МЬ 

♦ 

41256 

♦ 

$ІММ 

1 МЬ 

♦ 0 8 МЬ 

♦ 

44256 

♦ 

$ІРР 

1 МЬ 

♦ Другие комплектующие 

♦ 

411000 

♦ 

ЗІММ 

4 МЬ 

динамической памяти на заказ 


Немедленная поставка. На все комплектующие гарантия — 1 год. 


Наши специалисты приедут к Вам: 

— выполнят все работы по расширению памяти; 

— окажут квалифицированные консультации по работе с программным обеспече- 
нием, использующим расширенную память. 

Форма оплаты любая. Цены умеренные. 

Для оптовых и постоянных клиентов предоставляется скидка. 

АО «ПИРИТ» 

115446 , Москва, Коломенский проезд, Іа 
проезд: м. Коломенская, авіп.220, 219; ост. Электромеханический колледж. 

Тел.: (095) 112-72-10 Факс: (095) 112-72-10 

С НАМИ В ЗАВТРАШНИЙ ДЕНЬ! 




ВНИМАНИЮ ВЛАДЕЛЬЦЕВ ПЕРСОНАЛЬНЫХ КОМПЬЮТЕРОВ! 


ВАШИ ИНТЕЛЛЕКТУАЛЬНЫЕ И КОММЕРЧЕСКИЕ 
ВОЗМОЖНОСТИ МНОГОКРАТНО ВОЗРАСТУТ, ЕСЛИ ВЫ 
ДОПОЛНИТЕ СВОИ АРМы МОДЕМОМ ИСМ-1200 

Асинхронный полудуплексный внешний модем 
ИСМ-1200 предназначен для передачи 
текстовой и графической информации между 
компьютерами, находящимися на любых 
расстояниях друг от друга по обычной 
телефонной сети (внутренней, городской, 
междугородной) . 

Достоинства: 

- соответствует международному стандарту Ѵ.23 
ССІТТ и требованиям общегосударственной 
телефонной связи 

- обладает преимуществом по сравнению с 
зарубежными Науез-совместимыми модемами 
стандартов Ѵ.22 и Ѵ.22Ьіз МЫР5 по надежности 
и устойчивости передачи данных при 
использовании на отечественных телефонных 
линиях 

- доступ к биржевой, банковской, коммерческой, 
справочной информации, в базы данных и 
получение других услуг через информационную 
систему “СИТЕК“ 

- широкий спектр программного обеспечения 


МОДЕМ ИСМ-1200 — ЭТО: 


ТОВАР ВЫСШЕГО 
КАЧЕСТВА 


послегарантийное обслуживание, обучение, 
консультации и поддержка тысяч пользователей модемов 
осуществляются нашими представительствами в 45 городах 
страны. 


Приглашаем партнеров для взаимовыгодного 
сотрудничества и открытия региональных 
представительств фирмы 

Оптовым покупателям предоставляется скидка 
Немедленная поставка без предоплаты 

НАУЧНО-ПРОИЗВОДСТВЕННАЯ ФИРМА “МАСТАК“ 

107241 Москва, а/я 13. Факс: (095)360-78-74 
Фирменное обслуживание: Москва, ул. Знаменская, 8. 
Телефон: (095)168-20-21 



ФИРМЕННЫЙ 
СЕРВИС ДЛЯ 
ПОЛЬЗОВАТЕЛЯ 


ДОСТИЖЕНИЯ 

САМОЙ 

ПЕРЕДОВОЙ 

ТЕХНОЛОГИИ 

Гарантийное и 



Технические характеристики: 

- связь модема с компьютером через 
последовательный интерфейс К5-232С 

- использование с ІВМ РС ХТ/АТ, ЕС 1841-1845, 
Искра 1030, Турбо 86М, Микро 86 и другими 

- стандарт Ѵ.23 ССІТТ 

- скорость передачи 300-1800 бит/с 

- габаритные размеры 252x175x66 мм 

- масса 1.8 кг 
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Новости 


1 1 марта в Москве было объявлено о 
начале сотрудничества фирм Іпіеі и 
ЗЬагр в области разработки и произ- 
водства технологий и продуктов флэш- 
памяти. Соединив исследовательскую 
мощь двух фирм с опытом их произ- 
водства, накопленным Іпіеі, эти фирмы 
надеются способствовать значитель- 
ному расширению рынка продуктов 
флэш-памяти. 

Флэш-память — это ПЗУ большой 
емкости, особенностями которой явля- 
ются возможность электрического пе- 
репрограммирования и высокое бы- 
стродействие. Наиболее вероятными 
областями использования этой револю- 
ционной технологии являются быстро- 
действующие накопители, которые по- 
зволят заменить винчестеры в порта- 
тивных и обычных компьютерах, опе- 
ративная память переносных компью- 
теров, не теряющая информации при 
выключении питания и позволяющая 
продолжать выполнение задачи с того 
же места. 

Партнеры будут проводить совмест- 
ные разработки, развивать производст- 
во и технологии, основанные на самой 
современной 0.6-микронной техноло- 
гии, что позволит в очередной раз по- 
высить степень интеграции микросхем. 
Кроме того, теперь фирма 8Нагр, яв- 
ляющаяся одним из лидеров в области 
портативных компьютеров, сможет по- 
купать элементы флэш-памяти у Іпіеі 
для использования в собственной про- 
дукции и для продажи от имени 8Ьагр. 
В свою очередь, увеличение производ- 
ства флэш-памяти фирмой ЗЬагр вы- 
зовет увеличение производства на Іпіеі, 
которое потребуется для удовлетворе- 
ния потребностей существующего и 
нового рынков. По прогнозам 
Эаіациезі, этот рынок вырастет со 
130 млн.долл. в настоящий момент до 
1.5 млрд.долл. к 1995 году. 

Ком пьютерПресс, 
11 марта , 1992 


Іпіеі представила 

чип 486БХ2 еще и в Москве 

Случилось это 11 марта. Процессор 
работает с тактовой частотой 50 МГц, 
работая на 70% быстрее предыдущего 
поколения 486-х процессоров. 


486ЭХ2 полностью совместим с 
обычным 25-мегагерцовым 486ЭХ — 
можно просто заменить старый процес- 
сор на новый. Суть заключена в том, 
что узлы нового процессора работают с 
удвоенной тактовой частотой, в то 
время как для внешних устройств этот 
процессор представляет собой просто 
более быстрый 25-мегагерцовый 80486. 
Скорее всего, компьютеры на этом 
чипе появятся сразу же после его 
презентации. 

Кроме того, на презентации была 
продемонстрирована потрясающе бы- 
страя рабочая станция Іпіеі на базе 
4860X2/50, поставки которой в СНГ 
осуществляет фирма ТеНпо. 

Ком пьютерПресс , 
* 11 марта , 1992 

Фирма СогеІ 8у$Іет$ выпустила 
очередную новинку в области исполь- 
зования оптических дисков. Это прог- 
рамма СогеІ СО Аисііо Гог \Ѵіпсіо\ѵ8, 
предназначенная для воспроизведения 
звуковых компакт-дисков на приводе 
для СО-КОМ, которыми все чаще 
оснащаются компьютеры. СогеІ СО 
Аисііо эмулирует работу СО-плейе- 
ра — панель выглядит и работает так 
же, как панель управления стандарт- 
ным СО-плейером. Дополнительные 
утилиты помогают настроить систему с 
учетом производительности накопителя 
и составить каталог любимых вещей на 
всех ваших компакт-дисках. Хороший 
интуитивный интерфейс помогает 
использовать программу без лишних 
проблем. 

КомпьютерПресс, 
11 марта, 1992 

Японская фирма А1р$ Еіесігіс 
выпустила мышь, формой и размером 
похожую на кредитную карточку. 

Устройство называется Сагсі роіпіег 
1ЮА09 и представляет собой плас- 
тинку толщиной 8 миллиметров и 
весом 60 грамм. Стоит 75 долларов. 
Фирма предполагает производить до 
100 тысяч таких приспособлений 
ежемесячно. Они особенно хороши для 
владельцев компьютеров-блокнотов. 

ИемзЬуІез Ыем$ ИеЫогк, 
МагсН 6, 1992 


Фирмы начинают продажи 
персональных компьютеров 
на базе 80486/50МГц 

Английская компания Еіопех объя- 
вила о начале продаж рС-450 — 
80486/50 МГц компьютера с супер- 
ѴСА монитором, 2 Мбайтами опера- 
тивной памяти, 50-Мбайтным винчес- 
тером за 1800 фунтов стерлингов. 
Машина имеет пару последовательных 
и параллельных портов и позволяет 
расширять память до 32 Мбайт на 
основной плате. 

. Аналогичное объявление сделала 
КасІіо 8Наск — фирма выпустила 
компьютер 4850Ер, который работает 
на процессоре 4860X2, недавно выпу- 
щенном фирмой Іпіеі. Касііо ЗНаск за- 
являет, что их машина будет под- 
держивать и ожидаемый в скором бу- 
дущем вариант этого процессора с так- 
товой частотой 66 МГц. 

Как и другие “50-мегагерцовые“ си- 
стемы, этот компьютер имеет тактовую 
частоту 25 МГц и удвоитель скорости, 
который обеспечивает рост производи- 
тельности на 70 % по сравнению с 
486/25. 

4850ЕР имеет 4 Мбайта ОЗУ, рас- 
ширяемые до 32 на основной плате, 
120-Мбайтный винчестер, два диско- 
вода гибких дисков, ѴСА-монитор, по- 
следовательные и параллельные порты. 
Стоит все удовольствие 2600 долларов. 
Улучшенная версия — с лазерным 
приводом и “улучшенными звуковыми 
возможностями “ обойдется в 

3499 долларов. 

Ые\ѵ$ЬуІе$ Ыемз Иеіуѵогк, 
Магсіі 5, 1992 


Фирма 8оГІ\ѵаге РиЫі$Ьіп§ 
объявила о перемене стратегии торгов- 
ли продуктами, имеющими однополь- 
зовательские и сетевые версии. Теперь 
каждый покупатель Нагѵагсі СгарЫсз 
Гог >Ѵіпсіо\ѵз, Нагѵагсі СгарЫсз 3.0, 
Нагѵагсі Эгаѵѵ Гог \Ѵіпсіо>ѵ8 и ргоГез- 
зіопаі \Ѵгііе ріиз сможет без дополни- 
тельной оплаты переустановить куп- 
ленную для одного компьютера версию 
на сети. 

Несколько изменены и цены паке- 
тов — Нагѵагсі СгарЫсз 3.0 — 
595 долларов; Нагѵагсі СгарЫсз Гог 
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>ѴіпсІтѵ8 — 595; Нагѵагсі Бга^ Гог 
\ѴіпсІо>ѵ8 — 595; ргоіеззіопаі \Ѵгііе 

ріиз — 249 долларов. 

ІѴемзЬуІез Ые\\?5 МеЫогк, 
МагсН 5, 1992 

Фирма АТ&Т решила уволить 6 
тысяч телефонисток, заменив их робо- 
тами-операторами. Профсоюз борется 
за отмену этого решения, но от техно- 
логии не уйдешь. 

МеѵзЬуіез ТѴеи'з Меімнэгк, 
МагсН 6, 1992 


А в Австралии продавцы жалуют- 
ся на то, что для комплектации прода- 
ваемых компьютеров не хватает винче- 
стеров емкостью менее 200 Мбайт. Все 
началось с пропажи 40 Мбайт приво- 
дов, потом — дисков по 80 Мбайт, а 
затем и 120- мегабайтных дисков. 

Высказываются три причины этого 
дефицита — либо производители ре- 
шили, что маленькие приводы скоро 
будут непопулярны и перестали их 
производить, либо они получили воз- 
можность производить эти большие 
диски с минимальным повышением се- 
бестоимости и решили извлечь допол- 
нительные прибыли, либо это моно- 
польное соглашение о том, чтобы ис- 
кусственно вытеснить дешевые диски и 
продавать большие дорогие приводы. 

МемзЬуШ Аеи'з МеЪѵогк, 
МагсН 5, 1992 


Фирма ІВМ опровергает слухи о 
том, что она сдалась и не будет бороть- 
ся с МісгозоІІ Ѵ/тс1о\ѵ8. Заявления о 
том, что фирма корректирует свою 
05/2, чтобы не вступать в тесную кон- 
куренцию с МісгозоГі, были сделаны 
представителями фирмы в газете 
Ѵогк Тітез. Другие высокопоставлен- 
ные представители ІВМ заявили, что 
это неправда, и что ІВМ продолжает 
бороться за продвижение 05/2 ѵ.2 как 
альтернативы и 005 и >Ѵіпс1оѵѵ8. 

Ые\^$Ьу1е$ Ыепз ЫеЪѵогк, 
МагсН 2, 1992 


МаІзизЫІа Еіесігіс и АТ&Т, 
вероятно, подпишут договор о 
совместной разработке компьютера с 
рукописным вводом информации. 
Фирмы создадут для этой цели сов- 
местное предприятие. МаІзизНііа также 
ведет переговоры с калифорнийской 
Еіесігопіс Агіз о совместной разработке 
машины для мультимедиа-систем. 
Компьютеры будут поддерживать опе- 
рационную систему, разработанную Со 
Согрогаііоп. 

ЫеуѵзЬуіез Ыеыя ЫеЫогк, 
МагсН 2, 1992 


Іпіеі подала в суд на СНірз & ТесН- 
поіо^іез за нарушение пяти своих па- 
тентов на 386-й процессор и одного на 
387-й. 

Кроме фирмы Іпіеі, свои собствен- 
ные, полностью совместимые с инте- 
ловскими, процессоры 386 и 387 про- 
изводят также Асіѵапсесі Місго Эеѵісез 
(АМО) и СНірз апсі ТесНпоІо^іез. АМЭ 
заявляет, что в 1991 году продала 
около двух миллионов этих чипов. 

Іпіеі и АМО судятся с 1990 года. 
Іпіеі подала иск в 1990 году, забрала 
его из суда, договорившись с АЛШ в 
следующем году. После этого АМО по- 
дала на Іпіеі, обвиняя ее в смертных 
грехах на сумму 2 миллиарда долларов 
и выиграла на прошлой неделе 
возмещение убытков в 15 миллионов. 
Похоже, что та же схема будет 
применена и к СНірз апсі ТесНпоІо^іез. 

СНірз апсі ТесНпоІо^іез защищается 
аналогичным образом, обвиняя Іпіеі в 
нарушении своих патентов. 

ЫемзЬуІез Ыеім^огк, 
МагсН 2, 1992 


Самая крупная японская компью- 
терная сеть МіПу-8егѵе начала 
предоставлять услуги по компьютер- 
ному переводу текстов с японского на 
корейский язык и наоборот. Аналогич- 
ная система для английского языка 
работает уже полгода. Заказ посыла- 
ется по сети, и так же возвращается, 
переведенный менее чем через сутки. 
Стоит услуга всего 5 иегі за слово. 

А ТемзЬуІез N^5 ЫеЪѵогк, 
МагсН 2, 1992 

Місго 2000 выпустила, по ее 
заявлению, первую в мире программу, 
которая позволяет делать низкоуровне- 
вое форматирование ШЕ-винчестеров. 
Программа называется Місго- 
зсоре 4.28. Стандарт приводов ШЕ, 
разработанный совместно Соппег рег- 
ірИегаІз и Сотрад и известный также 
как АТ-Ьиз, предусматривает наличие 
интеллектуального контроллера, 

который сам взаимодействует с 
диском, не давая операционной си- 
стеме возможности доступа непосред- 
ственно к диску. Місго 2000 удалось 
преодолеть это затруднение. Про- 
грамма стоит 450 долларов. 

ІЧем$Ьуіе$ Ыемз МеЫогк, 
МагсН 3, 1992 

Фирма Сотрач Сотриіег выпу- 
стила новое поколение своих монито- 
ров и контроллеров высокого разреше- 
ния. 

Мониторы (ЗѴізіоп имеют плоский 
15 или 17-дюймовый экран и стоят от 
900 до 1300 долларов. Специальная 


плата адаптера, поддерживающая эти 
мониторы, стоит еще 600 долларов. 

N оѵзЬуІез N^5 кеЬѵогк, 
МагсН 5, 1992 


По оценкам техасской исследова- 
тельской фирмы СНаппеІ Магке- 
Ііп§ Согрогаііоп, в 1999 году каждая 
американская семья будет иметь 
больше компьютеров, чем детей — а 
именно 2.2 штуки. 

По оценкам фирмы, в 1991 году 
было куплено 7 миллионов компьюте- 
ров, по сравнению с 5.1 миллионом — 
годом раньше. В настоящее время 
28 миллионов американских семей 
владеют 30 миллионами компьютеров. 

ЫемхЬуІез ІЯеРмогк, 
МагсН 3, 1992 


На выставке 

сотовой индустрии 
было много совместного 

Недавняя выставка СТІА в Нью- 
Орлеане продемонстрировала множе- 
ство совместных проектов компаний- 
операторов, обеспокоенных отсут- 
ствием роста числа звонков, но ни 
один из них не произвел такого 
впечатления, как показ, проведенный 
вне рамок выставки компанией- 
оператором кабельного телевидения 
Сох Сотгаипісаііопз. Председатель Сох 
Джеймс Кокс Кеннеди Цашез Сох 
Кеппесіу) позвонил председателю РСС 
Альфреду Сайксу в Вашингтон с 
помощью микроволнового сотового 
телефона и системы кабельного 
телевидения, которой владеет его 
компания. Кокс надеется создать 
сотовую микроволновую службу 
(рСГО, а Сайкс хочет дать ему право 
сделать это. Это может означать 
настоящую конкуренцию не только для 
операторов сотовой телефонии, но и 
для местных телефонных компаний. 

Особым вниманием на выставке 
пользовались Місгосеііз, небольшие, 
потребляющие мало энергии сотовые 
базовые станции, предназначенные для 
использования в зданиях и туннелях. 
Они рассматриваются как способ для 
операторов сотовых систем сразиться с 
грядущей конкуренцией со стороны 
рСІМ. Азігопеі, 90 процентами которой 
владеет японская МіІзиЬізНі, поставит 
60 устройств Місгосеіі для ВеІІ Аііапііс. 
расТеІ дала лицензию на свою микро- 
сотовую технологию фирме ЭесіЬеІ 
ргоОисІз (Даллас, США), так что она 
может производить конкурентоспособ- 
ный продукт. А компания Місгоѵѵаѵе 
Касііо (Чемсфорд, Массачусетс) пред- 
ставила новые цифровые микроволно- 
вые радиосистемы для объединения 
микросот без проводной связи. Они 
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уже получили “добро “ от регулиру- 
ющих инстанций США и Великобри- 
тании. 

Однако главными были два совмест- 
ных проекта. АтегіІесЬ, Веіі АИатіс, 
ЮГСѴЕХ и СТЕ создадут новую фирму, 
которая даст возможность трансляции 
разговоров сквозь 1 30 систем этих 
фирм. Этот проект будет конкуриро- 
вать с совместным проектом “Сеііиіаг 
Опе“ фирм МсСаѵѵ и 8ои0пѵе$1ет Веіі, 
при этом возникает вопрос: к какому 
из двух сетевых альянсов присоеди- 
нятся ВеІІЗоиіЬ и ІІЗ АѴезІ. Моіогоіа и 
Р^оНЬегп Теіесот образовали совмест- 
ное предприятие по продаже телефо- 
нов, сотовых узлов (базовых станций) 
и коммутаторов — от этого сильно 
проиграла компания ЦЗС Соттипіса- 
ііоп8, которая теперь не будет произво- 
дить сотовые коммутаторы для Мо- 
Югоіа. Новый альянс представляет со- 
бой крупнейшего поставщика сотового 
оборудования на североамериканском 
рынке. 

Наконец, СТЕ и Тапсіет Сотриіеге 
совместно разработают прикладную си- 
стему — информационную базу дан- 
ных об абонентах — для сотовых си- 
стем. Это поможет абонентам перехо- 
дить от системы к системе, переключая 
коммутаторы, и обеспечить услуги пе- 
редачи звонков и другие, аналогичные 
тем, которые предоставляют проводные 
телефонные сети. Это также понизит 
процент мошенничества в сотовой те- 
лефонии. 

ТНе Теіериііпв НоШпе, 
РеЬгиагу 17, 1992 


СНГ: Регистрация 
факсимильных аппаратов. 
Удвоение пропускной 
способности. 

Распространитель 
изделий АТ&Т 

Кирилл Чащин сообщил №ш$Ъу1е$, 
что московские телефонные власти на- 
чали массовую кампанию за регистра- 
цию факсимильных аппаратов. За те 
аппараты, которые зарегистрированы, 
взимается большая плата, хотя каче- 
ство линии не улучшается. Частное 
предприятие “Комп“ получило лицен- 
зию на сбор оплаты, которая состав- 
ляет около 2000 рублей за регистра- 
цию. Ежемесячная плата за телефон- 
ную линию с зарегистрированным 
факс-аппаратом составляет 108 рублей 
дополнительно, а плата за междуго- 
родную и международную связь на та- 
ких линиях удваивается. “Комп“ будет 
сертифицировать только определенные 
модели. Еженедельник “Коммерсант 
сообщил, что “Комп“ будет использо- 
вать “специальные технические сред- 
ства“ для обнаружения “подпольных 44 


факсимильных аппаратов и штрафо- 
вать владельца на 2000 рублей. 

Ъу1е$ Мозсош удалось обнаружить, что 
в факсимильный аппарат, по которому 
принимаются вопросы о регистрации, 
встроено устройство определения но- 
мера звонящего абонента. Цель всей 
этой кампании — собрать за следу- 
ющие два месяца 2-3 миллиона руб- 
лей. Западные предприятия, которые 
используют для своих факсов спе- 
циальные линии, уже зарегистриро- 
ваны, но они платят за услуги в твер- 
дой валюте. 

Тем временем ШВ Соттипісаііопз 
1 марта введет на своих линиях, веду- 
щих в СНГ, цифровое сжатие, что 
приведет к увеличению в два раза про- 
пускной способности каналов из США. 
Компания в настоящее время пропус- 
кает в среднем в день 15,000 минут 
трафика. 29 января эта цифра равня- 
лась 9,000 минут в день. ШВ осущест- 
вляет оптовую продажу своих мощно- 
стей ряду компаний, в основном Зргіпі, 
и в настоящее время является един- 
ственным оператором, предлагающим 
прямую связь со всеми республиками. 

Наконец, АТ&Т объявила о созда- 
нии совместного предприятия по про- 
даже своего оборудования в России. 
Оно получило название “Дальняя 
Связь“ (ДАЛО . АТ&Т будет принад- 
лежать 68% предприятия, в настоящее 
время АТ&Т борется за возможность 
продавать опто-волоконный кабель и 


развитые технологии в эту страну — 
сейчас это запрещено оставшимся с 
времен “холодной войны “ контролем 
над экспортом. “Дальняя Связь“ уста- 
новила в России существующую меж- 
дугородную сеть и занимается выпус- 
ком опто-волоконных систем, а также 
навигационного и медицинского обору- 
дования. 

ТНе Теіериііпв НоШпе, 
РеЬгиагу 17, 1992 


Сотовые телефоны: 

Моіогоіа - 

чемпион в легком весе 

Моіогоіа удерживает за собой ти- 
тул производителя самого легкого сото- 
вого телефона. Новейшая модель ком- 
пании — р4 — весит 220 грам- 

мов. Эта модель будет продаваться в 
этом месяце по цене 1,800 долларов, и 
ЫЕС собирается выпускать 60,000 те- 
лефонов в месяц. В Японии, однако, 
телефон продаваться не будет. Модели 
серии р4 отвечают североамериканско- 
му стандарту АМрЗ, европейскому Е- 
ТАС8 и стандарту NМТ, действу- 
ющему в Скандинавии и СНГ. Однако 
Моіогоіа сообщила, что теперь у нее 
есть еще более легкая модель — Міс- 
гоТас Ше весит меньше 210 граммов. 
Ее поставки начнутся в марте. 

ТНе ТеІериХіщ НоХІіпе, 
РеЬгиагу 17, 1992 


Автоматизированная 

система 

Менеджер 

малой фирмы 

Бухгалтерские проводки, Главная книга и Баланс, 
составляемые за любой период как по всей фирме, 
так и отдельно по каждому из ее подразделений, базы 
данных по персоналу и контрагентам, расчетно- 
платежные ведомости с автоматическим расчетом налогов 

и все это в удобной форме 

и в одной системе! 

Услуги бухгалтера требуются лишь для составления 
корреспонденции счетов, а вся работа по вводу 
и обработке данных может быть выполнена секретарем. 
Если же в конце квартала или года у Вас возникнут 
вопросы по составлению отчетности, то Вы можете 
обратиться в аудиторскую фирму “ЭКУРАН“, которая 
предоставит консультации квалифицированных 
специалистов и даже поставит Вас на полное 
бухгалтерское обслуживание. 

Более подробная информация о системе по телефонам: 

(095)269-50-23 

(095)252-89-97 


КомпьютерПресс 4'92 






Адреса 

книжных магазинов — 
опорных пунктов 
агентства 

“КомпьютерПресс** 

по распространению 
журнала 

КомпьютерПресс: 


1. 1 17334 Москва, 
Ленинский проспект, 40, 
“Техническая книга“, 
отдел “Книга почтой", 
тел. (095) 137-6019 

2 . Москва, 

Мясницкая, 6, 

“Книжный мир“ 

3. Москва, 

Чернышевского, 44, 

М-н №206 

4 . Москва, 

проспект Калинина, 26, 
“Дом книги“ 

5 . 630076 Новосибирск, 
Красный проспект, 60, 
“Техническая книга", 
отдел “Книга почтой" 

6. 620151 Свердловск, 
К.Либкнехта, 16, 
“Техническая книга". 
отдел “Книга почтой" 

7 . 191186 Санкт-Петербург, 
Невский проспект, 28, 

“Дом книги". , 

отдел “Книга почтой" 

8. 220005 Минск, 
Ленинский проспект, 48, 
“Техническая книга" 
отдел “Книга почтой" 


Совместное предприятие 
“ИНТЕРПРОКОМ“ 
и общество 
с ограниченной 
ответственностью 
“АВАРЕКС“ 

предлагают русскоязычную 
документацию по следующим 
программным продуктам: 

ВТКІЕѴЕ Іог 005 ѵ5.1 
ХТРІЕѴЕ РШ$ ѵ4.01 
ИЕТЛУАРЕ 501. ѵ2.1 1 
ИОѴЕЫ. ИЕТѴ/АКЕ 286 ѵ2.15 


За справками 
о порядке продажи 
обращаться по телефонам: 

Тверь: (08222)- 28-223 
Москва: (095) 129-80-09, 129-80-33 
Телефакс: (095) 310-70-91 


Агентство КомпьютерПресс 
продолжает принимать заявки 
на публикацию 
рекламных объявлений 


Широкий круг читателей, распространение 
по всей территории бывшего Советского 
Союза и большой тираж нашего ежемесячного 
журнала делают рекламу в КомпьютерПресс 

эффективной. 

Наши специалисты по рекламной 
деятельности подскажут, как лучше 
преподнести Ваш продукт, 
наши художники, фотографы и дизайнеры 
создадут красивый и лаконичный макет 
Вашей рекламы, наш журнал поможет Вам 
увеличить свое состояние. 

Реклама в КомпьютерПресс — 
это высокий класс! 

Реклама в КомпьютерПресс — 
это Ваш коммерческий успех! 




Наш адрес: 113093 Москва, а/ я 37 
Факс : (095) 200-22-89 
Телефон: (095) 471-32-63 
Е-таіІ: розіт аяіег@срге$х. т .нк. $и 






НИЧЕГО НОВОГО О НОВЫХ ПРОДУКТАХ НЕ\ѴЪЕТТ -РАСКАІШ ! 
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Не\ѵ1еІІ-Раскагй предлагает 

три новых изделия с уже знакомыми 

потребительскими свойствами 


Ьазегіеі ІІР Р1и§ 

- бесшумная и быстрая высококачественная печать 

- доступная цена (около 1500 долларов) 

- бесплатно прилагаемый картридж с русскими 
шрифтами 

- мощный процессор с тактовой частотой 16 МГц 

- стандартный объем оперативной памяти 
512 Кбайт (с возможностью расширения до 
4.5 Мбайт) 


Зсапіеі ІІР 

- разрешающая способ- 
ность 300 Орі 

- передача 256 оттенков 
серого 

- технология НР АссиРа§е, 
дающая отличные резуль- 
таты при работе с прог- 
раммами оптического 
распознавания символов 

- специальный 
программный интерфейс, 
обеспечивающий доступ 
как к основным оп-$сгееп 
функциям, так и к более 
сложным функциям из 
прикладных программ 
(текстовых процессоров, 
издательских пакетов и 
так далее). 


НР Ѵесіга 3868/20 

- процессор Іпіеі 3865Х с 
тактовой частотой 20 МГц 

- высокая степень 
внутренней интеграции, 
включая контроллер для 
подключения трех гибких 
дисков 

- пять свободных разъемов 
расширения 

- идеален для самостоя- 
тельного использования, 
хотя ориентированная на 
сетевое применение 
конструкция позволяет 
ему занять достойное 
место в семействе 
компьютеров для сетей 

- в стандартную 
конфигурацию входят 
клавиатура и интерфейсы 
ЗирегѴСА-монитора и 
мыши 

- современные и простые в 
использовании средства 
обеспечения защиты 
доступа к данным 


Итак, что мы имеем? Много новых полезных функций, многие функции улучшены, высокое качество 
и надежность — как и ожидалось. Конкурентоспособная цена, которая порадует Вас, и сервисное 
обслуживание, на которое всегда можно положиться. В общем, в духе Неѵѵіеіі-Раскагсі. 

На все это оборудование дается гарантия сроком 1 год. Обслуживание осуществляет превосходный сервисный 
центр фирмы Не\ѵ1еИ-РаскапІ, расположенный в Москве. 

Если Вам взгрустнулось, не переживайте — на улице весна. Позвоните на Не\ѵ1еИ-Раскагс1 или загляните 
в наш новый демонстрационный зал, где Вы познакомитесь с самым современным оборудованием, 
либо свяжитесь с одним из наших дилеров и Вы сами увидите, насколько близки и знакомы Вам наши новые 
изделия. 
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НЕѴѴІ-ЕТТ 

РАСКАРО 


АиіЬогігесі 

Оеаіег 


Официальные дилеры 
в СНГ 


Апі$ 

А5І 

САТ 

Сотриіегіапсі 

С55 

РоПгоп 

Нагс1-5оГі 

Місгогііп 

()ие$1 

Зіееріег 

Шігет 


(095)230-56-12 

(095)485-24-73 

(095)276-47-14 

(095)939-81-28 

(095)202-04-80 

(095)334-82-49 

(095)258-82-56 

(095)145-89-66 

(095)236-21-35 

(095)246-81-92 

(812)311-79-93 


Гах 230-21-82 
Гах 484-97-28 
Гах 276-47-12 
Гах 939-02-86 

Гах 334-82-49 
Гах 975-20-27 
Гах 148-34-39 
Гах 230-24-88 
Гах 246-74-46 
Гах 312-79-58 


Главный офис и сервис-центр 
Неѵѵіеіі-Раскагсі: 

129223 Москва , 
проспект Мира , 

ВДНХ у Деловой комплексу 
строение 2 

Телефон: (095)181-80-02 
Факс: (095)181-78-29 
Телекс: 414819 В8ТР 


кп НЕѴѴЫЕТТ 
Г РАСКАПО 

ВОЗМОЖНОЕ СТАЛО РЕАЛЬНЫМ 





СПррег 5.0 

ТИе Арріісаііоп Оеуе\ортеп[ ЗіапАагй 


Сііррег 5.0 - выбор профессионалов 


Вы думаете о том, как повысить качество разработок Ваших программистов, 
эффективность использования персональных компьютеров на Вашем предприятии? 

Если это так, то приобретение общепризнанного лидера в области разработок 
баз данных - Сііррег 5.0 — это решение Ваших проблем! 

Крупнейшие компании, правительственные учреждения, банки, концерны, большие и малые 
предприятия за рубежом и у нас в стране используют Сііррег. 

СЕГОДНЯ СПРРЕК 5.0 ПОЛНОСТЬЮ ПЕРЕВЕДЕН НА РУССКИЙ ЯЗЫК. 


Телефоны наших дилеров: 


Москва 

Владикавказ 

Мурманск 

906-00-88 

229-78-04 

347-69 

689-11 

329-45-33 

Донецк 

Нижний Тагил 

178-26-56 

442-57-92 

93-67-28 

23-57-98 

928-22-86 

Омск 

Находка 

141-50-08 

25-47-74 

255-67 

231-69-07 


257-06 

231-46-40 

Иркутск 


466-02-28 

43-77-29 

Чебоксары 

466-76-64 

46-56-14 

23-12-89 

434-20-60 

Таллинн 

23-07-84 

Новосибирск 

68-10-12 

Тверь 

35-35-23 

68-10-59 

282-09 

23-89-72 

35-69-31 

44-41-42 

490-60 

23-88-71 

Львов 

Абакан 

28-73-63 

72-26-61 

662-83 


Ст. Петербург 

Казань 

Екатеринбург 

164-88-74 

39-76-45 

44-84-53 

293-71-17 

38-01-02 

51-42-71 

568-39-34 

32-67-04 

34-37-43 

552-11-60 


34-57-40 

560-01-73 

Харьков 


293-29-59 

37-55-65 

Пермь 

210-46-01 


31-86-18 

466-35-97 

Ташкент 

76-48-63 

31-84-67 

Алма-Ата 


Самара 

39-02-59 

Киев 

51-64-18 


224-05-74 

37-05-53 

Красноярск 

228-34-36 


33-47-26 

269-04-09 

Шахт ы 
638-19 

Минск 

Владивосток 

267-64 

60-27-48 

25-46-72 


60-27-47 

26-41-10 



Техническая поддержка 
продуктов фирмы 
осуществляется СП “Магнит 14 , 
расположенным по адресу 
127018 Москва, ул. 2-я Ямская, 15. 
Телефон: (095)289-43-00 



